深入理解Linux中的grep命令
介绍
Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是GlobalRegularExpressionPrint,表示全局正则表达式版本,它的使用权限是所有用户。
grep[-acinv][--color=auto]'查找字符串'filename
参数:
-a:将binary文件以text文件的方式查找数据
-c:计算找到‘查找字符串'的次数
-i:忽略大小写的区别,即把大小写视为相同
-n:顺便输出行号
-v:反向选择,即显示出没有‘查找字符串'内容的那一行
-l:只显示匹配的文件,不显示具体内容
-f<规则文件>:指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
实例:
#取出文件/etc/man.config中包含MANPATH关键词的行,并把找到的关键字加上颜色 grep--color=autoMANPATH/etc/man.config #把ls-l的输出中包含字母file(不区分大小写)的内容输出 ls-l|grep-ifile #在文件'/var/log/messages'中查找关键词"Aug" grepAug/var/log/messages #在文件'/var/log/messages'中查找以"Aug"开始的行 grep^Aug/var/log/messages #选择'/var/log/messages'文件中所有包含数字的行 grep[0-9]/var/log/messages #在目录'/var/log'及随后的目录中搜索字符串"Aug"(递归查找) grepAug-R/var/log/* #在当前目录搜索带'energywise'行的文件 grep'energywise'* #在当前目录及其子目录下搜索'energywise'行的文件 grep-r'energywise'* #查找指定进程 ps-ef|grepsvn #从文件中读取关键词进行搜索,输出test.txt文件中含有从test2.txt文件中读取出的关键词的内容行 cattest.txt|grep-ftest2.txt
grep与正规表达式:
字符类的搜索:如果我想要搜寻test或taste这两个单字时,可以发现到,其实她们有共通的‘t?st'存在~这个时候,我可以这样来搜寻:
grep-n't[ae]st'regular_express.txt
其实[]里面不论有几个字节,他都谨代表某『一个』字节,所以,上面的例子说明了,我需要的字串是『tast』或『test』两个字串而已!
字符类的反向选择[^]:如果想要搜索到有oo的行,但不想要oo前面有g,如下
grep-n'[^g]oo'regular_express.txt
字符类的连续:再来,假设我oo前面不想要有小写字节,
grep-n'[^a-z]oo'regular_express.txt
当我们在一组集合字节中,如果该字节组是连续的,例如大写英文/小写英文/数字等等,就可以使用[a-z],[A-Z],[0-9]等方式来书写,那么如果我们的要求字串是数字与英文呢?呵呵!就将他全部写在一起,变成:[a-zA-Z0-9]。
我们要取得有数字的那一行,就这样:
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.txttest2.txt
总结
以上就是关于Linux中grep命令的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。