1.16. grep

  • 示例

$ echo -e "this is a word\\n\\next line"|grep word
this is a word

1.16.1. 参数说明

-c    # 显示匹配到得行的数目,不显示内容
-h    # 不显示文件名
-i    # 忽略大小写
-l    # 只列出匹配行所在文件的文件名
-E,   #--extended-regexp     模式是扩展正则表达式(ERE)
-n    # 在每一行中加上相对行号
-s    # 无声操作只显示报错,检查退出状态
-v    # 反向查找
-e    # 使用正则表达式
-w    # 精确匹配,匹配单词
-wc   # 精确匹配次数
-o    # 查询所有匹配字段
-P    # 使用perl正则表达式
-A3   # 打印匹配行和下三行
-B3   # 打印匹配行和上三行
-C3   # 打印匹配行和上下三行
-q  --quiet   #安静模式,不输出正常信息
--color     #显示颜色

1.16.2. grep–help

用法: grep [选项]... PATTERN [FILE]...
正则表达式选择与解释:
      -E, --extended-regexp     PATTERN 是一个可扩展的正则表达式(缩写为 ERE)
      -F, --fixed-strings       PATTERN 是一组由断行符分隔的字符串。
      -G, --basic-regexp        PATTERN 是一个基本正则表达式(缩写为 BRE)
      -P, --perl-regexp         PATTERN 是一个 Perl 正则表达式
      -e, --regexp=PATTERN      用 PATTERN 来进行匹配操作
      -f, --file=FILE           从 FILE 中取得 PATTERN
      -i, --ignore-case         忽略大小写
      -w, --word-regexp         强制 PATTERN 仅完全匹配字词
      -x, --line-regexp         强制 PATTERN 仅完全匹配一行
      -z, --null-data           一个 0 字节的数据行,但不是空行

    杂项:
      -s, --no-messages         不显示错误信息
      -v, --invert-match        选中不匹配的行
      -V, --version             显示版本信息并退出
          --help                显示此帮助并退出


    输出控制:
      -m, --max-count=NUM       NUM 次匹配后停止
      -b, --byte-offset         输出的同时打印字节偏移
      -n, --line-number         输出的同时打印行号
          --line-buffered       每行输出清空
      -H, --with-filename       为每一匹配项打印文件名
      -h, --no-filename         输出时不显示文件名前缀
          --label=LABEL         将LABEL 作为标准输入文件名前缀
      -o, --only-matching       只显示匹配PATTERN 部分的行
      -q, --quiet, --silent     不显示所有常规输出
          --binary-files=TYPE   设定二进制文件的TYPE 类型;
                                TYPE 可以是`binary', `text', 或`without-match'
      -a, --text                等同于 --binary-files=text
      -I                        等同于 --binary-files=without-match
      -d, --directories=ACTION  读取目录的方式;
                                ACTION 可以是`read', `recurse',或`skip'
      -D, --devices=ACTION      读取设备、先入先出队列、套接字的方式;
                                ACTION 可以是`read'或`skip'
      -r, --recursive           等同于--directories=recurse
      -R, --dereference-recursive       同上,但遍历所有符号链接
          --include=FILE_PATTERN  只查找匹配FILE_PATTERN 的文件
          --exclude=FILE_PATTERN  跳过匹配FILE_PATTERN 的文件和目录
          --exclude-from=FILE   跳过所有除FILE 以外的文件
          --exclude-dir=PATTERN  跳过所有匹配PATTERN 的目录。
      -L, --files-without-match  只打印不匹配FILEs 的文件名
      -l, --files-with-matches  只打印匹配FILES 的文件名
      -c, --count               只打印每个FILE 中的匹配行数目
      -T, --initial-tab         行首tabs 分隔(如有必要)
      -Z, --null                在FILE 文件最后打印空字符



    文件控制:
      -B, --before-context=NUM  打印文本及其前面NUM 行
      -A, --after-context=NUM   打印文本及其后面NUM 行
      -C, --context=NUM         打印NUM 行输出文本
      -NUM                      等同于 --context=NUM
          --color[=WHEN],
          --colour[=WHEN]       使用标记高亮匹配字串;
                                WHEN 可以是`always', `never'或`auto'
      -U, --binary              不要清除行尾的CR 字符(MSDOS/Windows)
      -u, --unix-byte-offsets   忽略CR 字符,报告字节偏移
                                 (MSDOS/Windows)
grep -v "a" txt                              # 过滤关键字符行
grep -w 'a\>' txt                            # 精确匹配字符串
grep -i "a" txt                              # 大小写敏感
grep  "a[bB]" txt                            # 同时匹配大小写
grep '[0-9]\{3\}' txt                        # 查找0-9重复三次的所在行
grep -E "word1|word2|word3"   file           # 任意条件匹配
grep ^[^#] file                             #搜索不以#开头的行
grep word1 file | grep word2 |grep word3     # 同时匹配三个
echo quan@163.com |grep -Po '(?<=@.).*(?=.$)'                           # 零宽断言截取字符串  # 63.co
echo "I'm singing while you're dancing" |grep -Po '\b\w+(?=ing\b)'      # 零宽断言匹配
echo 'Rx Optical Power: -5.01dBm, Tx Optical Power: -2.41dBm' |grep -Po '(?<=:).*?(?=d)'           # 取出d前面数字 # ?为最小匹配
echo 'Rx Optical Power: -5.01dBm, Tx Optical Power: -2.41dBm' | grep -Po '[-0-9.]+'                # 取出d前面数字 # ?为最小匹配
echo '["mem",ok],["hardware",false],["filesystem",false]' |grep -Po '[^"]+(?=",false)'             # 取出false前面的字母
echo '["mem",ok],["hardware",false],["filesystem",false]' |grep -Po '\w+",false'|grep -Po '^\w+'   # 取出false前面的字母

1.16.3. grep用于if判断

if echo abc | grep "a"  > /dev/null 2>&1
then
    echo "abc"
else
    echo "null"
fi