find、三剑客之grep、正则表达式

find

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

    语法格式:
        find   [查找范围]  [参数]

    参数:
        -name : 按照文件的名字查找文件
            * :通配符
        -iname :  按照文件的名字查找文件(忽略大小写)
        -size : 按照文件的大小查询文件
            +	: 大于
            -	: 小于
            没符号 : 等于

        -mtime : 按照修改时间去查询
            +(可以省略) : n 天以前
            - 			: n 天以内
        -atime
        -ctime 

        -user :按照用户的属主查询
        -group : 按照用户的属组查询
        -type : 按照文件的类型查询
            d : 文件夹
            l : 链接文件
            s : 套接字文件
            p : 管道文件
            c : 字符文件
            b :磁盘文件
            f : 普通文件

        -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 : 把处理的文本变成以空格分割的一行
        `` : 提前执行命令,然后将结果交给其他命令来处理

image

三剑客之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

image

正则表达式

    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次
        +      :匹配至少有一个前导字符
        ?      : 匹配一个或零个前导字符
        |      :或

    案例:
        案例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

image

posted @ 2021-12-20 19:54  丶祈安  阅读(41)  评论(0编辑  收藏  举报