摘录自:https://10.linuxstory.net/grep-regular-expressions/
Linux 系统自带了支持拓展正则表达式的 GNU 版本 grep 工具。所有的 Linux 系统中默认安装的都是 GNU 版 grep 。grep 命令被用来检索一台服务器或工作站上任何位置的文本信息。
正则表达式只不过是每个输入行匹配的模式。模式是一个字符序列。下面都是范例:
例如:“^w1”、“w1|w2”、“[^ ]”。
例子中,使用了扩展正则表达式的模式。
<strong>grep ^vivek /etc/passwd</strong>
输出结果示例:
vivek:x:1000:1000:Vivek Gite,,,:/home/vivek:/bin/bash
vivekgite:x:1001:1001::/home/vivekgite:/bin/sh
固定检索内容的位置:你可以使用 ^ 和 $ 符号强制一个正则表达式分别匹配一行的开始或结束的位置。下面的示例显示以 ‘vivek’ 开头的文本。
如何匹配具体字符?
匹配 ‘Vivek’ 或 ‘vivek’ :
1<strong>grep '[vV]ivek' FILENAME</strong>
或者可以这样:
1<strong>grep '[vV][iI][Vv][Ee][kK]' FILENAME</strong>
你可以匹配数字(例如匹配 vivek1 或 Vivek2 ):
1<strong>grep -w '[vV]ivek[0-9]' FILENAME</strong>
你可以匹配两位数(例如匹配 foo11 , foo12 ):
1<strong>grep 'foo[0-9][0-9]' FILENAME</strong>
不仅仅是数字,你可以匹配字母:
1<strong>grep '[A-Za-z]' FILENAME</strong>
显示所有包含 “w” 或 “n” 字母的文本行:
1<strong>grep [wn] FILENAME</strong>
选项 摘选自:https://man.linuxde.net/grep
-a不要忽略二进制数据。
-A<显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容。
-b在显示符合范本样式的那一行之外,并显示该行之前的内容。
-c计算符合范本样式的列数。
-C<显示列数>或-<显示列数>除了显示符合范本样式的那一列之外,并显示该列之前后的内容。
-d<进行动作>当指定要查找的是目录而非文件时,必须使用这项参数,否则grep命令将回报信息并停止动作。
-e<范本样式>指定字符串作为查找文件内容的范本样式。
-E将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。
-f<范本文件>指定范本文件,其内容有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每一列的范本样式。
-F将范本样式视为固定字符串的列表。
-G将范本样式视为普通的表示法来使用。
-h在显示符合范本样式的那一列之前,不标示该列所属的文件名称。
-H在显示符合范本样式的那一列之前,标示该列的文件名称。
-i忽略字符大小写的差别。
-l列出文件内容符合指定的范本样式的文件名称。
-L列出文件内容不符合指定的范本样式的文件名称。
-n在显示符合范本样式的那一列之前,标示出该列的编号。
-q不显示任何信息。
-R/-r 此参数的效果和指定“-d recurse”参数相同。
-s不显示错误信息。
-v反转查找。
-w只显示全字符合的列。
-x只显示全列符合的列。
-y此参数效果跟“-i”相同。
-o只输出文件中匹配到的部分。
grep命令常见用法
在文件中搜索一个单词,命令会返回一个包含“match_pattern”的文本行:
grep match_pattern file_name
grep "match_pattern" file_name
在多个文件中查找:
grep "match_pattern" file_1 file_2 file_3 ...
输出除之外的所有行 -v 选项:
grep -v "match_pattern" file_name
标记匹配颜色 --color=auto 选项:
grep "match_pattern" file_name--color=auto
使用正则表达式 -E 选项:
grep -E "[1-9]+"或 egrep "[1-9]+"
只输出文件中匹配到的部分 -o 选项:
echo this is a testline. | grep -o -E "[a-z]+\."line.
echo this is a test line. |egrep -o "[a-z]+\."line.
统计文件或者文本中包含匹配字符串的行数 -c 选项:
grep -c "text" file_name
输出包含匹配字符串的行数 -n 选项:
grep "text"-nfile_name 或 cat file_name | grep "text" -n
#多个文件 grep "text" -n file_1 file_2
打印样式匹配所位于的字符或字节偏移:
echo gun is not unix | grep -b -o "not"
7:not
#一行中字符串的字符便宜是从该行的第一个字符开始计算,起始值为0。选项-b -o一般总是配合使用。
搜索多个文件并查找匹配文本在哪些文件中:
grep -l "text" file1 file2 file3...