元数据、修改时间戳、文件名通配、定义命令的别名、I/O重定向及管道

 

文件的元数据

文件的数据分为两类:一类为元数据,既属性数据;一种就是数据本身:
  数据是指普通文件中的实际数据
  元数据指用来描述一个文件的特征的系统数据,诸如访问权限、文件拥有者以及文件数据块的分布信息(inode…)等等

那么如何查看文件的详细信息?

stat命令:

功能说明:
    显示inode内容
命令用法:
    stat  [文件或目录]
演示示例:

显示/etc目录下fstab文件的相信信息: 
[root@localhost ~]# stat /etc/fstab 
  File: "/etc/fstab"
  Size: 860           Blocks: 8          IO Block: 4096   普通文件
Device: fd00h/64768d    Inode: 1048583     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-11-02 22:16:28.604999999 +0800
Modify: 2016-11-02 22:04:35.291999640 +0800
Change: 2016-11-02 22:13:17.833999187 +0800

各参数的含义:
File:文件的路径
Size: 文件大小
Blocks: 这个文件使用的块的总数
IO Block:这个文件的IO块大小
普通文件:表示文件的类型
Device:十六进制设备号,设备数量的小数
Inode:Inode号是一个独特的号码,操作系统用inode号码来识别不同的文件
Links:到文件的链接数
Access(0644/-rw-r--r--):文件的权限
Uid:文件所有者的UID和用户名
Gid:文件所有者的GID和组名
access time:表示我们最后一次访问(仅仅是访问,没有改动)文件的时间
modify time:表示我们最后一次修改文件的时间
change time:表示我们最后一次对文件属性改变的时间,包括权限,大小,属性等等
补充:

Linux系统上的文件类型:

 例如:
    [root@localhost ~]# ls -l /etc/fstab 
    -rw-r--r--. 1 root root 860 11月  2 22:04 /etc/fstab

    “-rw-r--r--”最前面的 “ - ”即表示文件的类型 
        -:常规文件;即f;
        d:directroy,目录文件;
        b:block device,快设备文件,支持以“block”为单位进行随机访问;
        c:character device,字符设备文件,支持以“character”为单位进行线性访问;
            major number:主设备号,用于标识设备类型,进而确定要加载的驱动程序
            minor unmber:次设备号,用于标识同一类型中的不同设备
                8位二进制:0-255
        l:symbolic link,符号链接文件;
        p:pipe,命名管道;
        s:socket,套接字文件;

如何修改文件的时间戳信息?

  上面使用stat命令查看文件的详细信息时显示了三个关于文件的时间信息, 那么如何修改这三个时间信息呢?

touch命令:

功能说明:
    修改文件的时间戳,或者新建一个不存在的文件。
命令用法:
    touch [options]… FILE…
常用选项:
    -c:指定文件路径不存在时不予创建
    -a:仅修改 access time
    -m:仅修改 modify time
    -t STAMP  :使用指定的日期时间
           [[cc]YY]MMDDhhmm[.ss] 即[年]月日小时分钟[秒]
演示示例:

1、在/tmp/a_c目录下创建文件test1
    [root@localhost ~]# cd /tmp/a_c
    [root@localhost a_c]# touch test1
    [root@localhost a_c]# ll
    总用量 0
    -rw-r--r--. 1 root root 0 11月  4 01:42 test1

2、修改文件test1文件的access time
    首先用stat命令查看到test1的access time时间为2016-11-04 01:46:24
    使用touch命令修改:
    [root@localhost a_c]# touch -a -t  11040201 test1
    再次stat:时间已经改为
    Access: 2016-11-04 02:01:00.000000000 +0800

定义命令的别名

命令别名:将一个命令用其他名字来代替
获取所有可用别名的定义:
     ~]# alias
定义别名:
     ~]# alias NAME='COMMAND'
         注:仅对当前shell进程有效
撤销别名:
     ~]# unalias NAME

glob实现文件名通配

所谓通配是指:显示以指定条件的文件
匹配模式:元字符

     *:匹配任意长度的任意字符  
     ?:匹配任意单个字符  
     []:匹配指定范围内的任意单个字符  
     字符集的表示方法:  
                        [[:upper:]]:表示所有大写字母
                        [[:lower:]]:表示所有小写字
                        [[:alpha:]]:表示所有字母
                        [[:digit:]]:表示所有数字
                        [[:alnum:]]:表示所有的字母和数字
                        [[:space:]]:表示所有空白字符
                        [[:punct:]]: 表示标点符号
        [^]:匹配指定范围外的任意单个字符,与[]相反,即取反

I/O重定向和管道

输出重定向:

            COMMAND > NEW_POS , COMMAND >> NEW_POS

            输出重定向:>
                特性:覆盖输出,目标文件汇总的原有内容会被清除
            输出重定向:>>
                特性:追加输出,新内容会追加至目标文件尾部

            # set -c
                禁止覆盖输出重定向至已存在的文件
                此时可使用强制覆盖输出:>
            # set +c
                关闭上述特性
            错误输出流重定向:2>,2>>

输入重定向:

tr命令:
            tr [OPTION]... SET1 [SET2]
                        把输入的数据当中的字符。凡是在SET1定义范围内出现的,通通转换为SET2出现的字符
            用法1:
                tr SET1 SET2 < /path/to/somefile
            用法2:
                tr -d SET1 < /path/to/somefile

            Here Doucment:<<
                cat << EOF    
                cat > /path/to/somefile <<EOF

管道:链接程序,实现将前一个命令的输出直接定向后一个程序当做输入数据流
      COMMAND1 | COMMAND2 | COMMAND3 | …      

        

 

练习:

1、显示 /var 目录下所有以 l  开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。

            [root@localhost ~]# ls -d /var/1?[[:lower:]]

2、显示 /etc 目录下,以任意一个数字开头,且以非数字结尾的文件或目录。

            [root@localhost ~]# ls  /etc/[0-9]*[^0-9]

3、显示 /etc 目录下,以非字母开头,

            [root@localhost ~]# ls /etc/[^a-z][a-z]*

4、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。

            [root@localhost ~]# touch /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S)

5、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

            [root@localhost ~]# cp -r /etc/p*[^0-9] /tmp/mytest1

6、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。

            [root@localhost ~]# cp -r /etc/*.d /etc/mytest2

7、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

            [root@localhost ~]# cp -r /etc/[lmn]*.conf /etc/mytest3

 

原创文章,作者:641348038@qq.com,如若转载,请注明出处:http://www.178linux.com/57460

(0)
641348038@qq.com641348038@qq.com
上一篇 2016-11-06
下一篇 2016-11-06

相关推荐

  • 流式传输的两大主流种类及流式传输特点

     流式传输定义很广泛,现在主要指通过网络传送媒体(如视频、音频)的技术总称。其特定含义为通过Internet 将影视节目传送到PC机。实现流式传输有两种方法:实时流式传输(Realtime streaming)和顺序流式传输(progressive streaming)。(百度百科)     在网络上传输音/视频(英文…

    Linux干货 2015-04-10
  • N28-第四周

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。
    2、编辑/etc/group文件,添加组hadoop。
    3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。
    4、复制/etc/skel目录为/home/hadoop,要求修改hadoop目录的属组和其它用户没有任何访问权限。
    5、修改/home/hadoop目录及其内部所有文件的属主为hadoop,属组为hadoop。
    6、显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式;
    7、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
    8、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
    9、找出/etc/passwd文件中的一位数或两位数;
    10、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
    11、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
    12、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
    13、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

    2017-12-30
  • sed 文本处理工具介绍

    sed简介: 文本处理三剑客之一的sed sed是一种行编辑器,它一次处理一行内容,本身是一个管道命令,对行的数据进行 替换 增加 删除 选取的工作 sed的命令为:sed[opition] ‘script’ inputfile…             &nbs…

    2017-06-24
  • bash脚本编程之算术运算和文件查找

    算数运算在每个编程语言里面是最基本的功能,在bash里面也是.相对于其他编程语言来说在bash里面不能直接以变量加上变量的形式来表现;比如我们先声明两个变量num1和num2然后再做运算。 num1=2 num2=3 echo "$num1+$num2" 2+3 这里我们显示的结果直接为2+3只是做了变量的替换,而不是做两个变量…

    Linux干货 2016-12-23
  • LINUX课堂笔记(第二周)

    2018.03.12 rpm httpd*** service httpd start ab 模仿用户访问 cat /var/log/httpd/access_log curl 访问web服务 rev 字符颠倒显示 sort  -r 执行反方向(由上至下)整理  -R 随机排序  -n 执行按数字大小整理  -f 选项忽略(fold)字符串中的字符大…

    Linux干货 2018-03-17
  • AWK——文本处理三剑客

    GNU awk ·文本处理三工具:grep,sed,awk          grep,egrep,fgrep:文本过滤工具:pattern          sed:行编辑器  &nbsp…

    Linux干货 2016-09-20

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-10 20:24

    总结的不错~赞~继续加油~