实地代码
[maintenance@localhost ~]$ python
Python 2.7.5 (default, Nov 6 2016, 00:28:07)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-11)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import os
>>> import statvfs
>>> vfs = os.statvfs("/home")
>>> vfs
posix.statvfs_result(f_bsize=4096, f_frsize=4096, f_blocks=521728, f_bfree=144359, f_bavail=144359, f_files=1048576, f_ffree=1005229, f_favail=1005229, f_flag=4096, f_namemax=255)
>>> dir(statvfs)
['F_BAVAIL', 'F_BFREE', 'F_BLOCKS', 'F_BSIZE', 'F_FAVAIL', 'F_FFREE', 'F_FILES', 'F_FLAG', 'F_FRSIZE', 'F_NAMEMAX', '__builtins__', '__doc__', '__file__', '__name__', '__package__']
>>> available=vfs[statvfs.F_BAVAIL]*vfs[statvfs.F_BSIZE]/(1024*1024*1024)
>>> available
0
>>> available=vfs[statvfs.F_BAVAIL]*vfs[statvfs.F_BSIZE]/(1024*1024)
>>> available
563
>>> capacity=vfs[statvfs.F_BLOCKS]*vfs[statvfs.F_BSIZE]/(1024*1024)
>>> capacity
2038
>>> used=capacity-available
>>> used
1475
参数
path -- 文件路径。
返回值
返回的结构:
f_bsize: 文件系统块大小
f_frsize: 分栈大小
f_blocks: 文件系统数据块总数
f_bfree: 可用块数
f_bavail:非超级用户可获取的块数
f_files: 文件结点总数
f_ffree: 可用文件结点数
f_favail: 非超级用户的可用文件结点数
f_fsid: 文件系统标识 ID
f_flag: 挂载标记
f_namemax: 最大文件长度
statvfs的数据结构,成员信息
struct statvfs {
unsigned long f_bsize; /* file system block size */
unsigned long f_frsize; /* fragment size */
fsblkcnt_t f_blocks; /* size of fs in f_frsize units */
fsblkcnt_t f_bfree; /* # free blocks */
fsblkcnt_t f_bavail; /* # free blocks for non-root */
fsfilcnt_t f_files; /* # inodes */
fsfilcnt_t f_ffree; /* # free inodes */
fsfilcnt_t f_favail; /* # free inodes for non-root */
unsigned long f_fsid; /* file system ID */
unsigned long f_flag; /* mount flags */
unsigned long f_namemax; /* maximum filename length */
};
使用statvfs读取文件系统信息
///文件操作偏移地址启用64位形式
#define _FILE_OFFSET_BITS 64
#include <stdio.h>
#include <sys/statvfs.h>
typedef enum {
TOTAL_SIZE,///文件系统的大小
FREE_SIZE, ///*空间
USED_SIZE, ///已用空间
AVAIL_SIZE ///用户实际可以使用的空间
}VFsize;
//把数字大小转换成字符形式
char *
byte_size_to_string(fsblkcnt_t size)
{
const double k = 1024;
const double m = k*1024;
const double g = m*k;
static char size_str[128] = {0};
if(size>=g)
sprintf(size_str,"%0.2lf GB",size/g);
else if(size>=m)
sprintf(size_str,"%0.2lf MB",size/m);
else if(size>=k)
sprintf(size_str,"%0.2lf KB",size/k);
else
sprintf(size_str,"%0.0lf Byte",size>=0?size:0.0);
return size_str;
}
///文件系统的各种信息数据的大小
fsblkcnt_t
get_vfs_size(struct statvfs *buf,VFsize flag)
{
fsblkcnt_t block;
fsblkcnt_t bsize;
bsize = buf->f_bsize;
switch (flag){
case TOTAL_SIZE:
block = buf->f_blocks;
break;
case FREE_SIZE:
block = buf->f_bfree;
break;
case USED_SIZE:
block = buf->f_blocks - buf->f_bavail;
break;
case AVAIL_SIZE:
block = buf->f_bavail;
break;
default:
block = 0;
break;
}
return bsize * block;
}
int main(int argc, char **argv)
{
char *pathname;
struct statvfs buf;
fsblkcnt_t total_size;
fsblkcnt_t used_size;
fsblkcnt_t avail_size;
int error;
pathname = "/";
if(argc>1){
pathname = argv[1];
}
//把文件系统信息读入 struct statvfs buf 中
error = statvfs(pathname,&buf);
//错误检查
if(error <0){
fprintf(stderr,"statvfs():%m\n");
return error;
}
//输出结果,此结果与gparted一致,与df出入较大
printf("FileSystem of \'%s\':\n",pathname);
total_size = get_vfs_size(&buf,TOTAL_SIZE);
printf(" total:%s\n",byte_size_to_string(total_size));
used_size = get_vfs_size(&buf,USED_SIZE);
printf(" used :%s\n",byte_size_to_string(used_size));
avail_size = get_vfs_size(&buf,AVAIL_SIZE);
printf(" Avail:%s\n",byte_size_to_string(avail_size));
return 0;
}