Linux中的grep 命令中的正则表达式2019-11-19

摘录自:https://10.linuxstory.net/grep-regular-expressions/

Linux 系统自带了支持拓展正则表达式的 GNU 版本 grep 工具。所有的 Linux 系统中默认安装的都是 GNU 版 grep 。grep 命令被用来检索一台服务器或工作站上任何位置的文本信息。

正则表达式只不过是每个输入行匹配的模式。模式是一个字符序列。下面都是范例:

例如:“^w1”、“w1|w2”、“[^ ]”。

例子中,使用了扩展正则表达式的模式。

grep ^vivek /etc/passwd

输出结果示例:

vivek:x:1000:1000:Vivek Gite,,,:/home/vivek:/bin/bash

vivekgite:x:1001:1001::/home/vivekgite:/bin/sh

固定检索内容的位置:你可以使用 ^ 和 $ 符号强制一个正则表达式分别匹配一行的开始或结束的位置。下面的示例显示以 ‘vivek’ 开头的文本。


如何匹配具体字符?

匹配 ‘Vivek’ 或 ‘vivek’ :

1grep '[vV]ivek' FILENAME

或者可以这样:

1grep '[vV][iI][Vv][Ee][kK]' FILENAME

你可以匹配数字(例如匹配 vivek1 或 Vivek2 ):

1grep -w '[vV]ivek[0-9]' FILENAME

你可以匹配两位数(例如匹配 foo11 , foo12 ):

1grep 'foo[0-9][0-9]' FILENAME

不仅仅是数字,你可以匹配字母:

1grep '[A-Za-z]' FILENAME

显示所有包含 “w” 或 “n” 字母的文本行:

1grep [wn] FILENAME

选项  摘选自: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...

你可能感兴趣的:(Linux中的grep 命令中的正则表达式2019-11-19)