Centos下grep命令简介

来源:互联网 发布:巨人网络财报 编辑:程序博客网 时间:2024/05/22 08:04

grep命令简介

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-20141116

2、搜索含有 error 字样的行,并且输出行号

grep -n 'error' /var/log/httpd/error_log-20141116

3、搜索没有 error 字样的行,并且输出行号

grep -nv 'error' /var/log/httpd/error_log-20141116

4、搜索寻找安装的软件版本有几个

#centos下查看安装的Python版本rpm -qa | grep -i python#Ubuntu下查看安装的Python版本sudo dpkg -l | grep -i python

5、过滤配置文件的注释符号#

#匹配 # 符号的行,但是输出的是 # 符号以外的行grep -v '#' /etc/httpd/conf/httpd.conf

6、查询每个网卡和IP地址

ifconfig | grep -n inet

 7、忽略大小写搜索(-i)

grep -i "ErroR" log.txt

8、所有子目录下的搜索(-r)

 grep -r "exception" log.txt

 9、精准全匹配搜索(-w)

grep -w "boo" /path/to/file

 10、精准全字匹配搜索两个不同单词

grep -w 'word1|word2' /path/to/file

 11、统计字符串出现的次数(-c)

grep -c 'word' /path/to/file#-n的话, 会在结果中,列出匹配字符串的序列号,并且会列出内容grep -n 'word' /path/to/file

 12、只列出文件名(-l)

grep -l 'main' *.pls

 13、高亮显示搜索结果(–color)

grep --color apache /etc/passwd

grep正则表达式元字符集整理

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。
0 0
原创粉丝点击