Linux之shell文本搜索工具grep

文本搜索工具grep

作用

  • grep是linux中一种强大的文件搜索过滤工具,可以按照正则表达式检索文件内容,并把匹配的结果显示到屏幕上(匹配的内容会标红)

格式

[root@server ~]# grep   -参数   条件  文件名
#条件就相当于检索的内容

参数

参数 功能
-i 忽略大小写
-c 统计匹配的行数
-v 取反,不显示匹配的行
-w 匹配整个单词,精确匹配
-E 等价于egrep,即启用扩展正则表达式
-n 显示行号
-rl 将指定目录内的文件打印
-A数字 匹配行及以下n行
-C数字 匹配行及上下n行
-B数字 匹配行及以上n行
-q 静默模式,没有任何内容输出,使用$?来判断是否执行成功
-o 只显示匹配的内容

注意

  • 工作方式grep可以在一个多个文件检索,如果条件中包含了空格,需要使用双引号引起
  • 工作结果:如果搜索成功则返回0状态码,否则为1状态码

示例

  • 操作对象文件:/etc/passwd
    • 作用:记录账户的信息,共分为7段,使用冒号分割
    • 意义:账户名:密码代号x:UID:GID:注释:家目录:登录的Shell
    • 注意:最后一段/sbin/nologin表述不允许登录
[root@server ~]# grep -n "root" /etc/passwd   #-n显示行号
[root@server ~]# grep  -n  "sshd"  /etc/passwd
[root@server ~]# grep  -n  "/sbin/nologin"  /etc/passwd


[root@server ~]# grep  -c  "/bin/bash"  /etc/passwd  #显示匹配的行数
12
[root@server ~]# grep "/bin/bash" /etc/passwd | wc -l
12


[root@server ~]# grep -nv "/sbin/nologin" /etc/passwd  #-v取反,表示可以登录的

[root@server ~]# grep  -ni  "d"  /etc/passwd  #-i忽略大小写

[root@server ~]# grep -nA2 "ftp" /etc/passwd  ##包含ftp的行以及以下2行

[root@server ~]# grep -nB3 "ftp" /etc/passwd  #包含ftp的行以及以上3行

[root@server ~]# grep  -nC3  "ftp"  /etc/passwd  #包含ftp的行以及以上下3行

正则表达式

概念

  • 在进行程序设计的过程中,用户会不可避免地遇到处理某些文本的情况。有的时候,用户还需要查找符合某些比较复杂规则的字符串。对于这些情况,如果单纯依靠程序设计语言本身,则往往会使得用户通过复杂的代码来实现。但是,如果使用正则表达式,则会以非常简短的代码来完成
  • 正则表达式是通过一些特殊字符的排列,用以查找、替换、删除一行或多行文字字符串,简单的说,正则表达式就是用在字符串的处理上面的一项表示式。由于正则表达式语法简练,功能强大,得到了许多程序设计语言的支持,包括Java、C++、Perl以及Shell等

基本正则表达式

  • 基本正则表达式(Basic Regular Expression,BRE),又称为标准正则表达式,是最早制订的正则表达式规范,仅支持最基本的元字符集。基本正则表达式是POSIX规范制订的两种正则表达式语法标准之一,另外一种语法标准称为扩展正则表达式

常见元字符

元字符 说明
^ 以某个字符开头或行首
$ 以某个字符结尾或结尾
. 匹配任意字符
* 对前一项进行0次或多次重复匹配
{m,n} 将前一项字符重复m-n次,{m,}{,n}{m,n}
[] 对方括号内的单字符进行匹配
[^] 对方括号内的范围取反
1 匹配以某个字符开头的行
() 定义一个子表达式
词首【\<或\b】和词尾锚定【\>或者\b】 其后面的任意字符必须作为单词首部出现;其前面的任意字符必须作为单词尾部出现
\ 转义字符,让一些特殊符号失效

posix字符类

  • POSIX字符类是一个形如[:...:]的特殊元序列(meta sequence),他可以用于匹配特定的字符范围
正则表达式 描述 示例
[:alnum:] 匹配任意一个字母数字字符 [[:alnum:]]+
[:alpha:] 匹配任意一个字母字符(包括大小写字母) [[:alpha:]]
[:blank:] 空格与制表符(横向和纵向) [[:blank:]]*
[:digit:] 匹配任意一个数字字符 [[:digit:]]?
[:lower:] 匹配小写字母 [[:lower:]]
[:upper:] 匹配大写字母 ([[:upper:]]+)?
[:punct:] 匹配标点符号 [[:punct:]]
[:space:] 匹配一个包括换行符、回车等在内的所有空白符 [[:space:]]+
[:graph:] 匹配任何一个可以看得见的且可以打印的字符 [[:graph:]]
[:xdigit:] 任何一个十六进制数(即:0-9,a-f,A-F) [[:xdigit:]]+
[:cntrl:] 任何一个控制字符(ASCII字符集中的前32个字符) [[:cntrl:]]
[:print:] 任何一个可以打印的字符 [[:print:]]

示例

  • [ab] : 检索包含a或者b的行信息,[]只能包含一个内容
[root@server ~]# grep  -n  [dD]  /etc/passwd
[root@server ~]# grep  -n  [oo]  /etc/passwd
  • [^]:根据关键字反向显示(反向着色)
[root@server ~]# grep  -n  [^o]  /etc/passwd
[root@server ~]# grep  -n  [^r]oot  /etc/passwd
  • [-]:表示范围,如:[0-9] [a-z] [A-Z] [a-zA-Z]
[root@server ~]# grep  -nw  [7-9]  /etc/passwd  #-w精确匹配整个范围

[root@server ~]# grep  -n  [A-Z]  /etc/passwd

[root@server ~]# grep  -n  [A-G]  /etc/passwd

[root@server ~]# grep  -n  [0-9A-Za-z]  /etc/passwd

[root@server ~]# grep  -n  [[:alnum:]]  /etc/sos/sos.conf #匹配字母,数字
  • ^行首与$行尾
[root@server ~]# grep -n  ^root  /etc/passwd  #匹配以root开头的行

[root@server ~]# grep  -n  ^#  /etc/sos/sos.conf   # 检索以#开头的注释行

[root@server ~]# grep  -n  "^\["  /etc/sos/sos.conf #\进行转义

[root@server ~]# grep  -n  "[0-9]$"   /etc/sos/sos.conf   #匹配以数字结尾的行

[root@server ~]# grep  -n  "^$"   /etc/sos/sos.conf #匹配空白行

[root@server ~]# grep  -n  ^[root]  /etc/passwd # 检索以r或o或t开头的不是root开头

[root@server ~]# grep  -n  ^root  /etc/passwd  # 整体对待

[root@server ~]# grep  -n  [^root]  /etc/passwd  # 检索不包含r或不包含o或不包含t,进行反向着色,注意:^[] 与  [^] 区别
  • 点(.)与星号(*)
[root@server ~]# grep  -n  r..t  /etc/passwd  #.代表匹配任意一个字符

[root@server ~]# grep  -n  ooo*    /etc/passwd  #*表示对前一项进行0次或多次重复匹配

[root@server ~]# grep  -n  "\."    /etc/passwd  #\进行转义
  • {m,n} 区间
[root@server ~]# grep  -n  "\<[0-9]\{2\}\>"  /etc/passwd
# {m,n}  描述区间

扩展正则表达式

概念

  • 扩展正则表达式(Extended Regular Expression,ERE)支持比基本正则表达式更多的元字符,但是扩展正则表达式对有些基本正则表达式所支持的元字符并不支持。前面介绍的元字符“^”、“$”、“.”、“*”、“[]”以及“[^]”这6个元字符在扩展正则表达式都得到了支持,并且其意义和用法都完全相同,不再重复介绍。接下来重点介绍一下在扩展正则表达式中新增加的一些元字符。

元字符

元字符 说明
将前一项字符进行0次或者1次的重复匹配
+ 将前一项进行1次或者多次的重复匹配
(|) 匹配|符号左边或者右边的字符,整体精确匹配

示例

[root@server ~]# grep  -n  "bash$"  /etc/passwd

[root@server ~]# grep  -n  "\<[[:digit:]]\{3,4\}\>"  /etc/passwd

[root@server ~]# grep  -n  "\<[0-9]\{3,4\}\>"  /etc/passwd

三种支持扩展正则的方法

[root@server ~]# egrep  -n  "^[[:space:]]+[^[:space:]]"  /etc/grub2.cfg 

[root@server ~]# grep  -nE  "^[[:space:]]+[^[:space:]]"  /etc/grub2.cfg 

[root@server ~]# grep  -n  "^[[:space:]]\+[^[:space:]]"  /etc/grub2.cfg 

注意:grep不支持扩展正则(? + (|)),要想生效,可以使用上述三种方法

# 将netstat  -tan显示结果中以LISTEN开头后跟0个或多个空白字符结尾的行信息
[root@server ~]# netstat  -tan  |  grep  "LISTEN[[:space:]]*$"
# 检索fdisk -l 命令结果中,包含/dev/开头后跟上n的行信息
[root@server ~]# fdisk -l  |  grep  "^/dev/n"
# 显示/etc/passwd中包含root、sshd、chrony的相关信息
[root@server ~]# egrep  -n  "(root|sshd|chrony)"  /etc/passwd
[root@server ~]# grep   -nE  "(root|sshd|chrony)"  /etc/passwd
# 检索ifconfig显示信息中结果为1-255间的整数
[root@server ~]# ifconfig |  egrep -o  "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]  )\>"   
# 取出echo输出的绝对路径名中的文件名
[root@server ~]# echo  /etc/yum.repos.d   |  egrep  [^/]+/?$
[root@server ~]# echo  /etc/yum.repos.d   |  egrep -o [^/]+/?$

  1. ↩︎

相关推荐

  1. Linuxshell文本搜索工具grep

    2024-03-21 23:46:01       42 阅读
  2. Linux文本三剑客:grep、awk、sed对比

    2024-03-21 23:46:01       61 阅读
  3. Linux文件和目录管理及文本搜索命令find grep

    2024-03-21 23:46:01       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-21 23:46:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-21 23:46:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-21 23:46:01       87 阅读
  4. Python语言-面向对象

    2024-03-21 23:46:01       96 阅读

热门阅读

  1. android VPN 数据包解析

    2024-03-21 23:46:01       47 阅读
  2. Python从入门到精通秘籍十一

    2024-03-21 23:46:01       43 阅读
  3. ARM day5

    2024-03-21 23:46:01       42 阅读
  4. Redis Pub/Sub: 实时消息传递的完美解决方案

    2024-03-21 23:46:01       45 阅读
  5. Python和FastAPI语义分析和文本图像

    2024-03-21 23:46:01       43 阅读
  6. css的scss

    2024-03-21 23:46:01       50 阅读
  7. 蓝桥杯2023年第十四届省赛真题-阶乘求和

    2024-03-21 23:46:01       65 阅读
  8. transformer的自注意力模型如何实现自注意力

    2024-03-21 23:46:01       48 阅读