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:]] 

原文地址:https://www.cnblogs.com/imcati/p/11601908.html