正则表达特殊符号
grep命令-字符串搜寻
-a :将 binary 档案以 text 档案的方式搜寻数据
-c :计算找到 '搜寻字符串' 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
实例:
查找小写字母:
grep -n '[[:lower:]]' regular_express.txt
查找数字:
grep -n '[[:digit:]]' regular_express.txt
搜寻特定字符串‘the’
$ grep -n 'the' regular_express.txt
$ grep -in 'the' regular_express.txt
$ grep -n 'the' regular_express.txt
反向查找,也就是说当该行没有”the“ 字符时才显示在屏幕上。
$ grep -vn 'the' regular_express.txt
grep命令-字符串匹配
[]中包含的任意一个字符。只能是一个。
字符组支持由连字符“ - ”来表示一个范围。当“ - ”前后构成范围时,要求前面字符的码位小于后面字符的码位。
[^...] 排除型字符组。排除后面的字符。
[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 结果返回为空,表明没有匹配到满足要求的字符串。
行首符^与行尾符$
找行首为大写字母的所有行:
'^[A-Z]' 表示以大写字母开头。
'[^A-Z]' 表示除了大写字母 A-Z 的所有字符。
grep -n '^[A-Z]' regular_express.txt
实例:
查找行首为“the”的字符行,则使用以下命令:
grep -n '^the' regular_express.txt
查找以 d 字母结尾的行:
grep -n 'd$' regular_express.txt
查找空行:
grep -n '^$' regular_express.txt
'^$' : 过滤掉空白行
'^#' :过滤掉注释行(以#号开头)
任意一个字符小数点与重复字符星号
(星号):代表重复前面 0 个或者多个字符。
e: 表示具有空字符或者一个以上 e 字符。
ee,表示前面的第一个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。
eee,表示前面两个 e 字符必须存在。第三个 e 则可以是 0 个或者多个 e 字符。
ee*e :表示前面的第一个与第三个 e 字符必须存在。第二个 e 则可以是 0 个或者多个 e 字符。
限定连续字符范围{}
{ }可限制一个范围区间内的重复字符数。举个例子,若要找出 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