zoukankan      html  css  js  c++  java
  • Linux-获取文件元数据

    除ls可以获取简单的元数据,获取文件详细的元数据(使用系统调用函数):stat(2)

    #include<sys/types.h>

    #include<sys/stat.h>

    #include<unistd.h>

    int stat(const char *path,struct stat *buf);

    功能:获取文件的状态信息

    参数:

        path:指定了文件的名字(包含路径)

        buf:用于接收文件的状态信息(注意它的类型)

    返回值:

        成功:0

        失败:-1,errno被设置


    原文链接:https://blog.csdn.net/qq_42216173/article/details/83088657

    文件系统中的数据分为两类,分别是数据和元数据。

    数据:指的是普通文件中的实际数据;

    元数据:指用来描述一个文件的特征的系统数据,诸如访问权限、文件拥有者、以及文件数据块的分布信息等等;

    查看文件的元数据信息需要用到一个命令:stat

    stat命令的作用为显示文件的状态信息,输出的信息比ls命令输出的信息更加详细。

    实例:

    [root@centos7mage ~]# stat /etc/sysconfig/network-scripts/ifcfg-eth0

      File: ‘/etc/sysconfig/network-scripts/ifcfg-eth0’

      Size: 118      Blocks: 8          IO Block: 4096  regular file

    Device: fd00h/64768d Inode: 33569832    Links: 1

    Access: (0644/-rw-r--r--)  Uid: (    0/    root)  Gid: (    0/    root)

    Context: system_u:object_r:net_conf_t:s0

    Access: 2018-10-11 09:46:00.346000000 +0800

    Modify: 2018-08-21 16:13:37.654010000 +0800

    Change: 2018-08-21 16:13:37.655010000 +0800

    Birth: -

    File:文件名称;

    Size:文件大小;

    Blocks:占用的磁盘块数;

    IO Block:IO块大小;

    regular file:这里是显示文件的类型,这是一个普通文件

    Device:所在设备;

    Inode:Inode节点号;

    Links:被链接的次数;(可以使用ln命令为文件添加硬链接或者软链接)

    Access(第一个):访问权限;

    Uid:uid号和属主;

    Gid:gid号和属组;

    Access(第二个):文件最近一次的访问时间;

    Modify:文件的修改时间;

    Chang:文件的改变时间。

    修改文件的时间戳需要使用一个命令:touch

    touch命令有两个功能:

    一、用于把已存在文件的时间标签更新为系统当前的时间(默认方式),他们的数据将原封不动地保留下来;

    二、用来创建新的空文件。

    实例:

    创建新的空文件:

    [root@centos6 app]# touch huangshizhang

    [root@centos6 app]# stat huangshizhang

      File: `huangshizhang'

      Size: 0        Blocks: 0          IO Block: 4096  regular empty file

    Device: 802h/2050d Inode: 12          Links: 1

    Access: (0644/-rw-r--r--)  Uid: (    0/    root)  Gid: (    0/    root)

    Access: 2018-10-25 09:56:35.134854810 +0800

    Modify: 2018-10-25 09:56:35.134854810 +0800

    Change: 2018-10-25 09:56:35.134854810 +0800

    修改文件的时间戳:

    [root@centos6 app]# touch huangshizhang

    [root@centos6 app]# stat huangshizhang

      File: `huangshizhang'

      Size: 0        Blocks: 0          IO Block: 4096  regular empty file

    Device: 802h/2050d Inode: 12          Links: 1

    Access: (0644/-rw-r--r--)  Uid: (    0/    root)  Gid: (    0/    root)

    Access: 2018-10-25 09:56:53.831856377 +0800

    Modify: 2018-10-25 09:56:53.831856377 +0800

    Change: 2018-10-25 09:56:53.831856377 +0800


    以下文章的原文链接:https://www.cnblogs.com/sylar5/p/6491033.html

    linux 中 stat 函数的用途和使用方法

    stat 函数讲解

    表头文件:    #include <sys/stat.h>

                     #include <unistd.h>

    定义函数:    int stat(const char *file_name, struct stat *buf);

    函数说明:    通过文件名filename获取文件信息,并保存在buf所指的结构体stat中

    返回值:      执行成功则返回0,失败返回-1,错误代码存于errno

    错误代码:

        ENOENT        参数file_name指定的文件不存在

        ENOTDIR        路径中的目录存在但却非真正的目录

        ELOOP          欲打开的文件有过多符号连接问题,上限为16符号连接

        EFAULT        参数buf为无效指针,指向无法存在的内存空间

        EACCESS        存取文件时被拒绝

        ENOMEM        核心内存不足

        ENAMETOOLONG  参数file_name的路径名称太长

    #include<sys/stat.h>

    #include<unistd.h>

    #include<stdio.h>

    int main() {

        struct stat buf;

        stat("/etc/hosts", &buf);

        printf("/etc/hosts file size = %d ", buf.st_size);

    }

    /*************************************************************************/

    struct stat {

        dev_t        st_dev;      //文件的设备编号

        ino_t        st_ino;//节点

        mode_t        st_mode;//文件的类型和存取的权限

        nlink_t      st_nlink;//连到该文件的硬连接数目,刚建立的文件值为1

        uid_t        st_uid;//用户ID

        gid_t        st_gid;//组ID

        dev_t        st_rdev;//(设备类型)若此文件为设备文件,则为其设备编号

        off_t        st_size;//文件字节数(文件大小)

        unsigned long st_blksize;//块大小(文件系统的I/O 缓冲区大小)

        unsigned long st_blocks;//块数

        time_t        st_atime;//最后一次访问时间

        time_t        st_mtime;//最后一次修改时间

        time_t        st_ctime;//最后一次改变时间(指属性)

    };

    先前所描述的st_mode 则定义了下列数种情况:

    S_IFMT  0170000    文件类型的位遮罩

        S_IFSOCK 0140000    scoket

        S_IFLNK 0120000    符号连接

        S_IFREG 0100000    一般文件

        S_IFBLK 0060000    区块装置

        S_IFDIR 0040000    目录

        S_IFCHR 0020000    字符装置

        S_IFIFO 0010000    先进先出

        S_ISUID 04000    文件的(setuser-idonexecution)位

        S_ISGID 02000    文件的(setgroup-idonexecution)位

        S_ISVTX 01000    文件的sticky位

        S_IRUSR(S_IREAD) 00400    文件所有者具可读取权限

        S_IWUSR(S_IWRITE)00200    文件所有者具可写入权限

        S_IXUSR(S_IEXEC) 00100    文件所有者具可执行权限

        S_IRGRP 00040            用户组具可读取权限

        S_IWGRP 00020            用户组具可写入权限

        S_IXGRP 00010            用户组具可执行权限

        S_IROTH 00004            其他用户具可读取权限

        S_IWOTH 00002            其他用户具可写入权限

        S_IXOTH 00001            其他用户具可执行权限

        上述的文件类型在POSIX中定义了检查这些类型的宏定义:   

      S_ISLNK (st_mode)    判断是否为符号连接

        S_ISREG (st_mode)    是否为一般文件

        S_ISDIR (st_mode)    是否为目录

        S_ISCHR (st_mode)    是否为字符装置文件

        S_ISBLK (s3e)        是否为先进先出

        S_ISSOCK (st_mode)  是否为socket

        若一目录具有sticky位(S_ISVTX),则表示在此目录下的文件只能被该文件所有者、此目录所有者或root来删除或改名。

    struct statfs {

        longf_type;//文件系统类型longf_bsize;//块大小longf_blocks;//块多少longf_bfree;//空闲的块longf_bavail;//可用块longf_files;//总文件节点longf_ffree;//空闲文件节点    fsid_t  f_fsid;          //文件系统idlongf_namelen;//文件名的最大长度longf_spare[6];//spare for later};

    stat、fstat 和 lstat 函数(UNIX)

    #include#include

    intstat(constchar*restrict pathname,structstat *restrict buf);

    stat 提供文件名字,获取文件对应属性。感觉一般是文件没有打开的时候这样操作。

    intfstat(intfiledes,structstat *buf);

    fstat 通过文件描述符获取文件对应的属性。文件打开后这样操作

    intlstat(constchar*restrict pathname,structstat *restrict buf);

    lstat 连接文件

    三个函数的返回:若成功则为0,若出错则为-1。

    给定一个pathname,stat函数返回一个与此命名文件有关的信息结构,fstat函数获得已在描述符filedes上打开的文件的有关信息。lstat函数类似于stat,但是当命名的文件是一个符号连接时,lstat返回该符号连接的有关信息,而不是由该符号连接引用的文件的信息。

    第二个参数是个指针,它指向一个我们应提供的结构。这些函数填写由buf指向的结构。该结构的实际定义可能随实现而有所不同,但其基本形式是:

    struct stat{

      mode_t st_mode;  /*file tpye &mode (permissions)*/  ino_t st_ino;    /*i=node number (serial number)*/  dev_t st_rdev;    /*device number for special files*/  nlink_t st_nlink; /*number of links*/  uid_t    st_uid;  /*user id of owner*/  gid_t    st_gid;  /*group ID of owner*/  off_t  st_size;  /*size in bytes for regular files*/  time_t st_atime;  /*time of last access*/  time_t st_mtime;  /*time of last modification*/  time_t st_ctime;  /*time of last file status change*/longst_blksize;/*best I/O block size */longst_blocks;/*number of 512-byte blocks allocated*/};

    注意,除最后两个以外,其他各成员都为基本系统数据类型。我们将说明此结构的每个成员以了解文件属性。

    使用stat函数最多的可能是ls-l命令,用其可以获得有关一个文件的所有信息。

    1) 函数都是获取文件(普通文件,目录,管道,socket,字符,块)的属性。

    函数原型:

    #include

    intstat(constchar*restrict pathname,structstat *restrict buf);

    提供文件名字,获取文件对应属性。

    intfstat(intfiledes,structstat *buf);

    通过文件描述符获取文件对应的属性。

    intlstat(constchar*restrict pathname,structstat *restrict buf);

    连接文件描述命,获取文件属性。

    2) 文件对应的属性

    struct stat {

            mode_t    st_mode;      //文件对应的模式,文件,目录等       

      ino_t      st_ino;        //inode节点号       

      dev_t      st_dev;        //设备号码       

      dev_t      st_rdev;      //特殊设备号码       

      nlink_t    st_nlink;      //文件的连接数       

      uid_t      st_uid;        //文件所有者       

      gid_t      st_gid;        //文件所有者对应的组       

      off_t      st_size;      //普通文件,对应的文件字节数       

      time_t    st_atime;      //文件最后被访问的时间       

      time_t    st_mtime;      //文件内容最后被修改的时间       

      time_t    st_ctime;      //文件状态改变时间       

      blksize_t st_blksize;    //文件内容对应的块大小       

      blkcnt_t  st_blocks;    //文件内容对应的块数量};

    可以通过上面提供的函数,返回一个结构体,保存着文件的信息。

  • 相关阅读:
    Linux上统计文件夹下文件个数
    linux----tail 过滤日志文件中的关键字
    Linux----Makefile
    Python--day 3
    Python--day 2
    Python--day 1
    Ubuntu14.04 64位网易云播放器
    qt 串口通信学习的目录
    qt layout 注意要点
    模拟电子第一章半导体
  • 原文地址:https://www.cnblogs.com/ptfe/p/10962223.html
Copyright © 2011-2022 走看看