grep 命令
NAME
grep, egrep, fgrep - print lines matching a pattern
SYNOPSIS
grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
参数:
-a 或 --text : 不要忽略二进制的数据。
-A<显示行数> 或 --after-context=<显示行数> : 除了显示符合范本样式的那一列之外,并显示该行之后的内容。
-b 或 --byte-offset : 在显示符合样式的那一行之前,标示出该行第一个字符的编号。
-B<显示行数> 或 --before-context=<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前的内容。
-c 或 --count : 计算符合样式的列数。
-C<显示行数> 或 --context=<显示行数>或-<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前后的内容。
-d <动作> 或 --directories=<动作> : 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-e<范本样式> 或 --regexp=<范本样式> : 指定字符串做为查找文件内容的样式。
-E 或 --extended-regexp : 将样式为延伸的正则表达式来使用。
-f<规则文件> 或 --file=<规则文件> : 指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
-F 或 --fixed-regexp : 将样式视为固定字符串的列表。
-G 或 --basic-regexp : 将样式视为普通的表示法来使用。
-h 或 --no-filename : 在显示符合样式的那一行之前,不标示该行所属的文件名称。
-H 或 --with-filename : 在显示符合样式的那一行之前,标示该行所属的文件名称。
-i 或 --ignore-case : 忽略字符大小写的差别。
-l 或 --file-with-matches : 列出文件内容符合指定的样式的文件名称。
-L 或 --files-without-match : 列出文件内容不符合指定的样式的文件名称。
-m num 或 --max-count=num : 最多匹配num次。
-n 或 --line-number : 在显示符合样式的那一行之前,标示出该行行号。
-o 或 --only-matching : 只显示匹配PATTERN 部分。
-q 或 --quiet或--silent : 不显示任何信息。
-r 或 --recursive : 此参数的效果和指定"-d recurse"参数相同。
-s 或 --no-messages : 不显示错误信息。
-v 或 --revert-match : 显示不包含匹配文本的所有行。
-V 或 --version : 显示版本信息。
-w 或 --word-regexp : 只显示全字符合的列。
-x --line-regexp : 只显示全列符合的列。
-y : 此参数的效果和指定"-i"参数相同。
--color : 颜色标亮显示。
--exclude=<file> : 搜索时排除某些文件。
--exclude-dir=<dir> : 搜索时排除某些目录。
--exclude-from=<file> : 指定文件进行多个文件排除。
示例:
grep -A3 deploy /etc/passwd //显示匹配文本的一行及之后的三行
grep -B3 deploy /etc/passwd //显示匹配文本的一行及之前的三行
grep -C3 deploy /etc/passwd //显示匹配文本的一行及前后的三行
grep -c root /etc/passwd //显示匹配文本的行数
grep -i DEPLOY /etc/passwd //忽略大小写匹配
grep -r deploy /tmp //遍历目录匹配文本
grep -lr deploy /tmp //输出匹配文本的名称
grep -n deploy /tmp/test/passwd //输出匹配文本在文本中的行号
grep -f keyfile /tmp/test/passwd //指定规则文件进行匹配,用于多条件匹配
grep --exclude-from=file deploy //排除多项文件不进行匹配
grep的正则表达式:
^word:搜寻以word开头的行。 示例:grep "^root" passwd //匹配以root开头的行
word$: 搜寻以word结束的行。示例:grep "bash$" passwd //匹配以bash结尾的行
.:匹配任意一个字符。示例:grep "ro.t" passwd
\:转义字符。
*: 前面的字符重复0到多次。 示例:grep "r*t" passwd
[list]:匹配一系列字符中的一个。示例:grep "ro[ou]t" passwd
[n1-n2]: 匹配一个字符范围中的一个字符。 示例:grep "ro[a-z]t" passwd
[^list]: 匹配字符集以外的字符。 示例:grep "[^root]" passwd
word\{n1\}: 前面的字符重复n1。示例:grep "ro\{2\}t" passwd
word\{n1,\}: 前面的字符至少重复n1。 示例:grep "ro\{1,\}t" passwd
word\{n1,n2\}: 前面的字符重复n1,n2次。示例:grep "ro\{1,5\}t" passwd
?:0个或1个在其之前的那个字符。示例:grep "roo\?t" passwd
+:1个或多个在其之前的那个字符。示例:grep "ro\+t" passwd
|:表示"或",匹配一组可选的字符,或(or)的方式匹配多个字串。示例:grep "root\|deploy" passwd
():表示一个字符集合或用在expr中,匹配整个括号内的字符串。示例:grep -E "(root|deploy)" passwd
常用的集合表示方法有:
纯数字:[[:digit:]]或[0-9]
小写字母:[[:lower:]]或[a-z]
大写字母:[[:upper:]]或[A-Z]
大小写字母:[[:alpha:]]或[a-zA-Z]
数字加字母:[[:alnum:]]或[0-9a-zA-Z]
空白字符:[[:space:]]
标点符号:[[:punct:]]
赠人玫瑰,手有余香,如果我的文章有幸能够帮到你,麻烦帮忙点下右下角的推荐,谢谢!
作者: imcati
出处: https://www.cnblogs.com/imcati/>
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接