返回介绍

第 2 节 grep 命令与正则表达式

发布于 2025-02-25 23:29:32 字数 4380 浏览 0 评论 0 收藏 0

一、搜寻特定字符串"the"

参数说明:

-a :将 binary 档案以 text 档案的方式搜寻数据

-c :计算找到 '搜寻字符串' 的次数

-i :忽略大小写的不同,所以大小写视为相同

-n :顺便输出行号

-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!

$ grep -n 'the' regular_express.txt

$ grep -in 'the' regular_express.txt

操作截图:

图片描述信息

图片描述信息

反向查找,也就是说当该行没有”the“ 字符时才显示在屏幕上。

$ grep -vn 'the' regular_express.txt

二、字符组匹配:

[]中包含的任意一个字符。只能是一个。

字符组支持由连字符“ - ”来表示一个范围。当“ - ”前后构成范围时,要求前面字符的码位小于后面字符的码位。

[^...] 排除型字符组。排除后面的字符。

[abc]       :表示“a”或“b”或“c”
[0-9]       :表示 0~9 中任意一个数字,等价于[0123456789]
[\u4e00-\u9fa5] :表示任意一个汉字
[^a1<]      :表示除“a”、“1”、“<”外的其它任意一个字符
[^a-z]      :表示除小写字母外的任意一个字符
查找“tast”或者“test”两个字符串。
# grep -n 't[ae]st' regular_express.txt 

# grep -n '^#' regular_express.txt  

操作截图:

图片描述信息

查找字符“oog”,如果我不想要“oog”字符前面有 g,则查找“[^g]oog”,同理,查找“[^go]oog”是指字符“oog”前面不能为 g 或者 o。

$ grep -n 'oog' regular_express.txt

$ grep -n '[^g]oog' regular_express.txt 

$ grep -n '[^go]oog'regular_express.txt 

操作截图:

图片描述信息

grep -n '[^go]oog'regular_express.txt 结果返回为空,表明没有匹配到满足要求的字符串。

三、行首符: ^ 与行尾符: $

在第一个小实验中,查找了一行字符中含有“the”的,如果你想要只查找 行首为“the”的字符行,则使用以下命令:

 $ grep -n '^the' regular_express.txt 

查找行首为大写字母的所有行:

'^[A-Z]' 表示以大写字母开头。

'[^A-Z]' 表示除了大写字母 A-Z 的所有字符。

# grep -n '^[A-Z]' regular_express.txt 

查找以 d 字母结尾的行:

# grep -n 'd$' regular_express.txt 

操作截图:

图片描述信息

查找空行:

$ grep -n '^$' regular_express.txt 

应用实例:

查看/etc/insserv.conf 文档

'^$' : 过滤掉空白行

'^#' :过滤掉注释行(以#号开头)

 $ cat -n /etc/insserv.conf

 $ grep -v '^$' /etc/insserv.conf | grep -v '^#'

四、任意一个字符: " . "(小数点)与重复字符 “ * ”(星号) 。

查找 a?ou?类型的字符。

$ grep -n 'a.ou.' regular_express.txt

'a.ou.' : 小数点表示任意一个字符,一个小数点只能表示一个未知字符。

*(星号):代表重复前面 0 个或者多个字符。
e*: 表示具有空字符或者一个以上 e 字符。
ee*,表示前面的第一个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。
eee*,表示前面两个 e 字符必须存在。第三个 e 则可以是 0 个或者多个 e 字符。
ee*e :表示前面的第一个与第三个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。

下面的第一条命令与第二条命令由于允许存在空字符,所以会打印所有文本。

$ grep -n 'e*' regular_express.txt 

$ grep -n '@*' regular_express.txt 

$ grep -n 'eee*' regular_express.txt 

五、限定连续字符范围{ }:

{ }可限制一个范围区间内的重复字符数。举个例子,若要找出 2~5 个 o 的连续字符串,如何做? 此时便要用到{}了。由于 { 与 } 在 shell 中有特殊意义,需要用到转义字符\。

查找连续的两个 o 字符:

$ grep -n 'o\{2\}' regular_express.txt

结果与命令 grep -n 'ooo*' regular_express.txt 的结果相同。

查找 g 后面接 2 到 5 个 o,然后再接 g 的字符串

$ grep -n 'go\{2,5\}g' regular_express.txt 
总结:
^word  表示带搜寻的字符串(word) 在行首

word$  表示带搜寻的字符串(word) 在行尾

.(小数点) 表示 1 个任意字符

\    表示转义字符,在特殊字符前加\会将特殊字符意义去除

*    表示重复 0 到无穷多个前一个 RE(正则表达式) 字符

[list]   表示搜索含有 list 的字符串

[n1-n2]  表示搜索指定的字符串范围,例如[0-9] [a-z] [A-Z]等

[^list]  表示反向字符串的范围,例如[0-9]表示非数字字符,[A-Z]表示非大写字符范围

\{n,m\}  表示找出 n 到 m 个前一个 RE 字符

\{n,\}   表示 n 个以上的前一个 RE 字符

参考文档:鸟哥的 linux 私房菜 鸟哥著 王世江 改编

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文