深入理解Linux中的grep命令

2019-09-23 09:16:22王冬梅

我们要取得有数字的那一行,就这样:

grep -n '[0-9]' regular_express.txt

行首与行尾字节 ^ $

行首字符:如果我想要让 the 只在行首列出呢? 这个时候就得要使用定位字节了!我们可以这样做:

grep -n '^the' regular_express.txt

开头是小写字节的那一行就列出呢?可以这样:

grep -n '^[a-z]' regular_express.txt

我不想要开头是英文字母,则可以是这样:

grep -n '^[^a-zA-Z]' regular_express.txt

^ 符号,在字符类符号(括号[])之内与之外是不同的! 在 [] 内代表『反向选择』,在 [] 之外则代表定位在行首的意义!

行尾结束为小数点 (.) 的那一行:

grep -n '.$' regular_express.txt

特别注意到,因为小数点具有其他意义(底下会介绍),所以必须要使用转义字符()来加以解除其特殊意义!

#找出空白行
grep -n '^$' regular_express.txt

任意一个字节 . 与重复字节 *

    . (小数点):代表『一定有一个任意字节』的意思;

    * (星号):代表『重复前一个字符, 0 到无穷多次』的意思,为组合形态

#需要找出 g??d 的字串,亦即共有四个字节, 起头是 g 而结束是 d ,我可以这样做:
grep -n 'g..d' regular_express.txt

#查找至少两个 o 以上的字串,『o*』代表的是:『拥有空字节或一个 o 以上的字节』
grep -n 'ooo*' regular_express.txt

#想要字串开头与结尾都是 g,但是两个 g 之间仅能存在至少一个 o ,亦即是 gog, goog, gooog.... 等等
grep -n 'goo*g' regular_express.txt

#找出 g 开头与 g 结尾的行,当中的字符可有可无
grep -n 'g.*g' regular_express.txt

#找到两个 o 的字串,可以是:
grep -n 'o{2}' regular_express.txt

#找出 g 后面接 2 到 5 个 o ,然后再接一个 g 的字串,他会是这样:
grep -n 'go{2,5}g' regular_express.txt

#2 个 o 以上的 goooo....g 呢?除了可以是 goo*g ,也可以
grep -n 'go{2,}g' regular_express.txt

#从多个文件中查找关键词
grep 'linux' test.txt test2.txt 

总结

以上就是关于Linux中grep命令的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。