日期:2014-05-16 浏览次数:20741 次
[root@test root]# grep [-acinv] '搜寻字符串' filename
参数说明:
-a :将 binary 档案以 text 档案的方式搜寻数据
-c :计算找到 '搜寻字符串' 的次数
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!
?
? 例题二、利用 [] 来搜寻集合字符
[root@test root]# grep -n 't[ae]st' regular_express.txt
[root@test root]# grep -n 'oo' regular_express.txt
[root@test root]# grep -n '[^g]oo' regular_express.txt
[root@test root]# grep -n '[^a-z]oo' regular_express.txt
[root@test root]# grep -n '[0-9]' regular_express.txt
?
? 例题三、行首与行尾字符 ^ $:
[root@test root]# grep -n '^the' regular_express.txt
[root@test root]# grep -n '^[a-z]' regular_express.txt
[root@test root]# grep -n '^[^a-zA-Z]' regular_express.txt
[root@test root]# grep -n '\.$' regular_express.txt
[root@test root]# grep -n '^$' regular_express.txt
[root@test root]# grep -v '^$' /etc/syslog.conf | grep -v '^#'
?
? 例题四、任意一个字符 . 与重复字符*
[root@test root]# grep -n 'g..d' regular_express.txt
[root@test root]# grep -n 'ooo*' regular_express.txt
[root@test root]# grep -n 'goo*g' regular_express.txt
[root@test root]# grep -n 'g.*g' regular_express.txt
[root@test root]# grep -n '[0-9][0-9]*' regular_express.txt
?
? 例题五、限定连续 RE 字符范围 {}
[root@test root]# grep -n 'o\{2\}' regular_express.txt
[root@test root]# grep -n 'go\{2,5\}g' regular_express.txt
[root@test root]# grep -n 'go\{2,\}g' regular_express.txt
?
????? 请特别留意的是,『正规表示法的特殊字符』与一般在指令列输入指令的『万用字符』并不相同, 例如,在万用字符当中,* 代表的是 0 ~ 无限多个字符的意思,但是在正规表示法当中, * 则是重复 0 到多个的前一个 RE 字符的意思~使用的意义并不相同,不要搞混了! (鸟哥我一开始摸正规表示法时就很容易
搞混!因为这里是新手最容易搞错的地方,特别小心啊!) 举例来说,不支持正规表示法的 ls 这个工具中,若我们使用『ls -l * 』代表的是任意档名的档案,而『ls -l a* 』代表的是以 a 为开头的任何档名的档案, 但在正规表示法中,我们要找到含有以 a 为开头的档案,则必须要这样:(需搭配支持正规表示法的工具)
ls | grep -n '^a.*'
另外,例如万用字符的反向选择,为 [!range] ,至于正规表示法则是 [^range] 。这样是否了解正规表示法与万用字符的差异啦??
?
延伸正规表示法