• grep 文本搜索工具


    参考百度百科

    1、简介

    grep (缩写来自Globally search a Regular Expression and Print)是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行

    2、语法

    grep [OPTIONS] PATTERN [FILE…]

    3、表达符集

    字符 说明 示例
    ^ 锚定行的开始 '^grep'匹配所有以grep开头的行
    $ 锚定行的结束 'grep$'匹配所有以grep结尾的行
    . 匹配一个非换行符('\n')的字符 'gr.p'匹配gr后接一个任意字符,然后是p
    * 匹配零个或多个先前字符 ' *grep' (注意*前有空格)匹配所有零个或多个空格后紧跟grep的行,需要用egrep 或者grep带上 -E 选项。 .*一起用代表任意字符。
    [] 匹配一个指定范围内的字符 '[Gg]rep'匹配Grep和grep
    [^] 匹配一个不在指定范围内的字符 '[^A-FH-Z]rep'匹配不包含A-F和H-Z的一个字母开头,紧跟rep的行
    \(..\) 标记匹配字符 '\(love\)',love被标记为1
    \< 锚定单词的开始 '\<grep'匹配包含以grep开头的单词的行
    \> 锚定单词的结束 'grep\>'匹配包含以grep结尾的单词的行
    x\{m\} 重复字符x,m次 'o\{5\}'匹配包含5个o的行
    x\{m,\} 重复字符x,至少m次 'o\{5,\}'匹配至少有5个o的行
    x\{m,n\} 重复字符x,至少m次,不多于n次 'o\{5,10\}'匹配5--10个o的行
    \w 匹配文字和数字字符,也就是[A-Za-z0-9] 'G\w*p'匹配以G后跟零个或多个文字或数字字符,然后是p
    \W \w的反置形式,匹配一个或多个非单词字符,如点号句号等  
    \b 单词锁定符 '\bgrep\b'只匹配grep
    \+ 匹配一个或多个先前的字符 '[a-z]\+able',匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等
    \? 匹配零个或一个先前的字符 'gr\?p'匹配gr后跟一个或没有字符,然后是p的行
    a\|b\|c 匹配a或b或c grep|sed匹配grep或sed
    \(\) 分组符号 love\(ab\le\|rs\)ov\+匹配loveable或lovers,匹配一个或多个ov

    4、参数

    参数 说明
    -? 同时显示匹配行上下的?行
    -b 打印匹配行前面打印该行所在的块号码
    -c 只打印匹配到的行数(统计行数),不显示匹配的内容
    -f File 从文件中提取模板。空文件中包含0个模板,所以什么都不匹配
    -h 当搜索多个文件时,不显示匹配文件名前缀
    -i 忽略大小写差别
    -o 只显示正则表达式匹配的
    -q 取消显示,只返回退出状态。0则表示找到了匹配的行,1为未匹配到,2为发生错误
    -n 在匹配的行前面打印行号
    -s 不显示关于不存在或者无法读取文件的错误信息(少用,一般将标准错误输出到/dev/null)
    -v 反检索,只显示不匹配的行
    -R,-r 递归的读取目录下的所有文件,包括子目录
    -V 显示软件版本信息
    -A6 查找某些字符的内容,并下延伸6行
    -B6 查找某些字符的内容,并上延伸6行
    -C1 查找某些字符的内容,并上和向下各延伸1行,这几行后面的数字直接影响延伸数量,并以--符号分割搜索行的结果
  • 相关阅读:
    Android开发中常见的错误
    使用命令行的方式向GitHub中上传本地项目
    jmeter保存测试结果到文件
    转 Jmeter参数化的4种方法
    键盘各键对应的编码值(key)
    CacheHelper对缓存的控制
    Oracle存储过程
    Oricle中SQL语法
    python学习资料百度网盘分享
    一些网站学习的链接
  • 原文地址:https://www.cnblogs.com/Xinenhui/p/16256867.html
Copyright © 2020-2023  润新知