grep 是一个最初用于Unix操作系统的命令行工具。在给出文件列表或标准输入后,grep会对匹配一个或多个正则表达式的文本进行搜索,并只输出匹配(或者不匹配)的行或文本。
grep 可根据提供的匹配模式列表,查询文件中的匹配行.发现匹配行后,行内容会被标准输出(默 认),如果使用了其它参数,可以产生其它格式的输出
grep 用于匹配文本,它对输入行的长度没有限制,除非受限于可用内存大小,并且可以匹配行内任意字符。
使用方法grep -[acinv] '搜索内容串' filename常用参数选项 -c 计算找到的符合行的次数。 -i 忽略大小写。 -n 显示匹配行及行号。 -v 找到没有搜索字符串的行。 -h 查询多文件时不显示文件名。 -l 查询多文件时只输出包含匹配字符的文件名。 -s 不显示不存在或无匹配文本的错误信息。 实际使用举例 1、搜索日志,查询有多少条503错误
grep -c '503' /var/log/httpd/error_log-201411162、搜索含有 error 字样的行,并且输出行号
grep -n 'error' /var/log/httpd/error_log-201411163、搜索没有 error 字样的行,并且输出行号
grep -nv 'error' /var/log/httpd/error_log-201411164、搜索寻找安装的软件版本有几个
#centos下查看安装的Python版本 rpm -qa | grep -i python #Ubuntu下查看安装的Python版本 sudo dpkg -l | grep -i python5、过滤配置文件的注释符号#
#匹配 # 符号的行,但是输出的是 # 符号以外的行 grep -v '#' /etc/httpd/conf/httpd.conf6、查询每个网卡和IP地址
ifconfig | grep -n inet7、忽略大小写搜索(-i)
grep -i "ErroR" log.txt8、所有子目录下的搜索(-r)
grep -r "exception" log.txt9、精准全匹配搜索(-w)
grep -w "boo" /path/to/file10、精准全字匹配搜索两个不同单词
grep -w 'word1|word2' /path/to/file11、统计字符串出现的次数(-c)
grep -c 'word' /path/to/file #-n的话, 会在结果中,列出匹配字符串的序列号,并且会列出内容 grep -n 'word' /path/to/file12、只列出文件名(-l)
grep -l 'main' *.pls13、高亮显示搜索结果(–color)
grep --color apache /etc/passwdgrep正则表达式元字符集整理 grep适用的正则表达式 ^ 锚定行的开始 如:’^grep’匹配所有以grep开头的行。 $ 锚定行的结束 如:’grep$’匹配所有以grep结尾的行。 . 匹配一个非换行符的字符 如:’gr.p’匹配gr后接一个任意字符,然后是p。 * 匹配零个或多个先前字符 如:’*grep’匹配所有一个或多个空格后紧跟grep的行。 [] 匹配一个指定范围内的字符,如'[Gg]rep’匹配Grep和grep。 [^] 匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep’匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。 .* 一起用代表任意字符。 \(..\) 标记匹配字符,如’\(love\)’,love被标记为1。 \<word 以某单词开头 word\> 以某单词结尾 x/{m/} 重复字符x,m次,如:’0\{5\}’匹配包含5个o的行。 x\{m,\} 重复字符x,至少m次,如:’o\{5,\}’匹配至少有5个o的行。 x\{m,n\} 重复字符x,至少m次,不多于n次,如:’o\{5,10\}’匹配5–10个o的行。 \w 匹配文字和数字字符 \b 单词锁定符,如: ‘\bgrep\b’只匹配grep。