Linux三剑客之grep(包含find&正则)

image

1. find

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

"语法格式:"
    find [查找范围/ ./...] [参数]
"参数:"
    -name    按照文件的名字查找文件
    *        通配符
    -iname   按照文件的名字查找(忽略大小写)
    等同于 -i  -name
    -size    按照文件的大小查找文件
       +n    大于指定大小
       -n    小于指定大小
    没有符号  等于
    -mtime   按照修改时间查询
    +(可以省略)  n天以前
    -           n天以内
    -ctime
    -atime
    -user    按照用户的属主查询
    -group   按照用户的属组查询
    -type    按照文件的类型查询
         f,l,d,s,p,c,b..
    -perm    按照文件的权限查询
    -inum    根据index node号码查询
    -a       并且(可以省略,默认是 并且)
    -o       或者
    -maxdepth  查询的目录深度(必须放置于第一个参数位)
    -exec    将前面find处理好的结果交给其他命令继续处理

"知识储备:"
    dd    生成文件
    # dd if=/dev/zero of=100.txt bs=10M count=10
        if:从什么地方读文件
        of:写入到什么文件
        bs:每次写入多少内容
        count:写入多少次

"案例:"
    案例1:
    查询/etc目录下hosts文件
    find [/etc/] -name 'hosts'

    案例2:
    查询/etc目录下名称中包含hosts文件
    find /etc/ -name '*hosts*'
    '*hosts'

    案例3:要求把/etc目录下,所有的普通文件打包压缩到/tmp目录
    tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`

"知识储备:"
    |:前面一个命令的结果交给后面的一个命令处理
    xargs:把处理的文本变成以空格分割的一行
    ``:提前执行命令,然后将结果交给其他命令来处理

2. grep

Linux三剑客之一,文本过滤器(根据文本内容过滤文件)
"语法格式:"
    grep [参数] [匹配规则(文本内部内容)] [操作对象]

"参数:"
    -n  过滤文本时,将过滤出来的内容在文件内的行号显示出来
    -A  匹配成功之后,将匹配行的后n行显示出来
    -B  匹配成功之后,将匹配行的前n行显示出来
    -C  匹配成功之后,将匹配行的前后各n行显示出来
    -c  只显示匹配成功的行数
    -o  只显示匹配成功的内容
    "-v"  反向过滤(非常重要)
    -q  静默输出(echo $?)
    -i  忽略大小写
    -l  匹配成功之后,将文本的名称打印出来
    -R/r  递归匹配
    # 在/etc目录下有多少个文件包含root,
    # grep -rl 'root' /etc/ | wc -l

    -E  使用拓展正则  等价于 egrep

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

3. 正则表达式

1. 正则表达式的分类(grep)
    1.普通正则表达式
    2.拓展正则表达式

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

3. 拓展正则(egrep或者grep -E)
    {}   匹配的次数
        {n}   匹配n次
        {n,}  至少匹配n次
        {n,m} 匹配n到m次
        {,m}  最多匹配m次,最少0次
    +    匹配至少有一个前导字符
    ?    匹配0个或1个前导字符
    |    或

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

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

    案例x:匹配
    grep 'f*'  test.txt 0和多个都匹配出来

    案例3:匹配本机中有哪些ip
    ip a | egrep -o '[0-9]{1,3}/.{3}[0-9]{1,3}'
	
    案例4:将/etc/fstab中去掉包含#开头的行,且要求# 后至少有一个空格
    egrep '^#\ +'  /etc/fstab

    案例5:找出文件中至少有一个空格的行
    egrep '\ +'
   
    案例6:将nginx.conf文件中以#开头的行和空行全部排除
    egrep -v '^\ *#|^$'  /etc/nginx/nginx.conf


posted @ 2021-12-20 18:49  Joshua_jiaxue  阅读(62)  评论(0编辑  收藏  举报