zoukankan      html  css  js  c++  java
  • 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:]] 

  • 相关阅读:
    Macaca拓展自己控件的方法
    pyparsing:定制自己的解析器
    利用 Traceview 精准定位启动时间测试的异常方法 (工具开源)
    Jenkins插件开发
    一个简陋的高并发请求脚本的演进过程
    python 自定义回调函数
    默认端口
    基本数据类型封装类比较
    grep命令和tail命令
    idea 拉取git新分支
  • 原文地址:https://www.cnblogs.com/imcati/p/11601908.html
Copyright © 2011-2022 走看看