Linux中find命令与grep命令

Linux中find命令与grep命令

  • find命令
  • grep命令
  • 正则表达式

 

一、find命令

  根据文件的名称或者属性查找文件

  语法格式:

find [查找范围] [参数]
    参数:
        -name:按照文件的名字查找文件
        *:通配符
        -iname:按照文件的名字查找文件(忽略大小写)
        -size:按照文件的大小查询文件
            +:大于
            -:小于
            没符号:等于
        -mtime:按照修改时间去查询
            +:n天以前(可以省略)
            -:n天以内
        -atime:按访问时间查询,用法与-mtime一致
        -ctime:按修改属性时间查询,用法与-mtime一致
        -user:按照用户的属主查询
        -group:按照用户的属组查询
        -type:按照文件的类型查询
            d:文件夹
            f:普通文件
            l:链接文件
            s:套接字文件
            p:管道文件
            c:字符文件
            b:磁盘文件
        -perm:按照文件的权限查询
        -inum:按照index node号码查询
        -a:并且(默认值,可以省略)
        -o:或者
        -maxdepth:查询的目录深度(必须放置在第一个参数位)
        -exec:将find处理好的结果交给其他命令继续处理

  知识储备:

    dd:生成文件

      if:从什么地方读

      of:写入到什么文件

      bs:每次写入多少内容

      count:写入多少次

  案例:

    案例1:查询/etc目录下hosts文件

[root@localhost ~]# find /etc/ -name 'hosts'
/etc/hosts

    案例2:查询/etc目录下名称中包含hosts的文件

[root@localhost ~]# find /etc/ -name '*hosts*'

    案例3:把/etc目录下所用的普通文件打包压缩到/tmp目录

[root@localhost /tmp]# tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`

  知识储备:

    |:前面一个命令的结果交给后面一个命令处理

    xargs:把处理的文本变成以空格分割的一行

    ``:提前执行命令,然后将结果交给其他命令来处理

 

二、grep命令

  Linux三剑客之一,文本过滤器(根据文本内容过滤文件)

  语法格式:

grep [参数] [匹配规则] [操作对象]
    参数:
    -n:过滤文本时,将过滤出来的内容在文件内的行号显示出来
    -A:匹配成功之后,将匹配行的后n行显示出来
    -B:匹配成功之后,将匹配行的前n行显示出来
    -C:匹配成功之后,将匹配行的前后各n行显示出来
    -c:只显示匹配成功的行数
    -o:只显示匹配成功的内容
    -v:反向过滤
    -q:静默输出
    -i:忽略大小写
    -l:匹配成功之后,将文本的名称打印出来
    -R|-r:递归匹配 
    -E:使用拓展正则   等价于  egrep

  知识储备:

$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。
wc :  匹配行数
    -l : 打印匹配行数
    -c : 打印匹配的字节数

  在/etc目录下,有多少个文件包含root

grep -rl 'root' /etc/ | wc -l

 

三、正则表达式

  1.正则表达式的分类(grep)

    1)普通正则表达式

    2)拓展正则表达式

  2.普通正则表达式

^:    以某字符开头
$:    以某字符结尾
.:    匹配除换行符之外的任意单个字符
*:    匹配前导字符的任意个数
[]:    某组字符串的任意一个字符
[^]:    取反
[a-z]:    匹配小写字母
[A-Z]:    匹配大写字母
[a-zA-Z]:    匹配字母
[0-9]:    匹配数字
\:    取消转义
():    分组
    \n:    代表第n个分组

  3.拓展正则表达式

{}:    匹配的次数
    {n}:    匹配n次
    {n,}:    至少匹配n次
    {n,m}:    匹配 n 到 m 次
    {,m}:    最多匹配m次
+:    匹配至少有一个前导字符
?:    匹配一个或零个前导字符
|:    或

  4.案例:

    案例1:在/etc/passwd文件中,匹配以ftp开头的行

grep '^ftp' /etc/passwd

    案例2:在/etc/passwd文件中,匹配以bash结尾的行

grep 'bash$' /etc/passwd

    案例3:匹配本机中有哪些ip

ip a | grep -oE '([0-9]{1,3}\.){3}[0-9]{1,3}'

    案例4:要求将/etc/fstab中的去掉包含 # 开头的行,且要求 # 后至少有一个空格

grep -vE '^#\ +' /etc/fstab

    案例5:找出文件中至少有一个空格的行

grep -E '\ +' xxx

    案例6:将 nginx.conf 文件中以#开头的行和空行,全部删除

grep -vE '^\ *#|^$' /etc/nginx/nginx.conf

 

posted @ 2021-12-20 21:35  尤露  阅读(157)  评论(0)    收藏  举报