Linux基础之正则表达式


一.find

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

语法格式:

 find  [查找范围]  [参数]

参数:

-name:按照文件的名字查找文件

-iname:按照文件名字查询文件(忽略大小)

-size:按照文件大小查询

  + :大于

  - :小于

  没符号:等于

-mtime:按照修改时间去查询

  +:n 天以前

  -:n天以后

-user:按照用户的属主查询

-group:按照用户的属组查询

-type:按照文件的类型查询

      d :文件夹

      l : 链接文件

      s : 套接字文件

      p :管道文件

      c : 字符文件

      b :磁盘文件

  f : 普通文件

-perm : 按照文件的权限查询

-inum : 根据index node号码查询

-a : 并且(可以省略,默认时并且)

-o : 或者

-maxdepth : 查询的目录深度(必须放置与第一个参数位)

-exec : 将find处理好的结果交给其他命令继续处理

知识储备:

    dd :生成文件

    if :从什么地方读

    bs:每次写入多少内容

    count: 写入多少次

知识储备:

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

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

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

二.grep

语法格式:

grep [参数] [匹配规则][操作对象]

参数:

-n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来

-A : 匹配成功之后,将匹配行的后n行显示出来

-B : 匹配成功之后,将匹配行的前n行显示出来

-C : 匹配成功之后,将匹配行的前后各n行显示出来

-c : 只显示匹配成功的行数

-o : 只显示匹配成功的内容

-v : 反向过滤

-q : 静默输出

-i : 忽略大小写

-l : 匹配成功之后,将文本的名称打印出来

-R|-r : 递归匹配

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

知识储备:

$? :上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。

wc : 匹配行数

-l : 打印匹配行数

-c : 打印匹配的字节数

三.正则表达式

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

 

相关