zoukankan      html  css  js  c++  java
  • linux下grep命令详解

    参数

    • -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 : 列出文件内容不符合指定的样式的文件名称。
    • -n 或 --line-number : 在显示符合样式的那一行之前,标示出该行的列数编号。
    • -q 或 --quiet或--silent : 不显示任何信息。
    • -r 或 --recursive : 此参数的效果和指定"-d recurse"参数相同。
    • -s 或 --no-messages : 不显示错误信息。
    • -v 或 --revert-match : 显示不包含匹配文本的所有行。
    • -V 或 --version : 显示版本信息。
    • -w 或 --word-regexp : 只显示全字符合的列。
    • -x --line-regexp : 只显示全列符合的列。
    • -y : 此参数的效果和指定"-i"参数相同。

    1. grep最简单的用法,匹配一个词:grep word filename

    2. 能够从多个文件里匹配:grep word filename1 filenam2 filename3

    3. 能够使用正則表達式匹配:grep -E pattern f1 f2 f3...

    4. 能够使用-o仅仅打印匹配的字符,例如以下所看到的:

    [root@zabbix net]# echo this is line. |grep -o "[a-z]*.$"
    line.
    [root@zabbix net]# echo this is line. |grep -o "[a-z]*."
    line.

    5. 打印除匹配行之外的其它行,使用-v:

    [root@zabbix net]# echo -e "1 2 3 4"
    1
    2
    3
    4
    [root@zabbix net]# echo -e "1 2 3 4"|grep -v "[1]"
    2
    3
    4
    [root@zabbix net]# echo -e "1 2 3 4"|grep -v "[1-2]"
    3
    4
    [root@zabbix net]# echo -e "1 2 3 4"|grep -v -E "[1-2]"
    3
    4

    6.统计匹配字符串的行数。使用-c

    [root@zabbix net]# echo -e "1 2 3 4"|grep "[1,2]" -c
    2

    7.统计字符串模式匹配的次数。能够结合-o。例如以下:

    前面的例子没有加 -o参数

    [root@zabbix net]# echo -e "11111222"|grep "[1,2]"
    11111222

    [root@zabbix net]# echo -e "11111222"|grep -o "[1,2]"
    1
    1
    1
    1
    1
    2
    2
    2
    8.假设须要显示行号,能够打开-n,例如以下

    [root@zabbix net]# echo -e "11111 222"|grep -n -o "[1,2]"
    1:1
    1:1
    1:1
    1:1
    1:1
    2:2
    2:2
    2:2
    [root@zabbix net]# echo -e "11111 222"|grep -n "[1,2]"
    1:11111
    2:222

    9. -b选项能够打印出匹配的字符串想对于其所在的行起始位置的偏移量(从0開始)。通常配合-o使用,例如以下:

    [root@zabbix net]# echo "0123456789" | grep -b -o 4
    4:4
    [root@zabbix net]# echo "012333456789" | grep -b -o 4
    6:4

    10.-P参数(声明grep后面要用的是正则表达式)

    [root@zabbix net]# echo -e " line.123 line."|grep -P "[a-z]*.d+"
    line.123
    [root@zabbix net]# echo -e " line.123 line."|grep -P "[a-z]*."
    line.123
    line.
    [root@zabbix net]# echo -e " line.123 line."|grep -P "[a-z]*.$"
    line.
    [root@zabbix net]# echo -e " line.123 line."|grep -P ".$"
    line.

    11.匹配多个字符串模式

    没有-o参数不会只打印匹配项

    [root@zabbix ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a"
    This is a line.

    添加-o参数之后只打印匹配项

    [root@zabbix ~]# echo "This is a line." | grep -o -e "This"
    This
    [root@zabbix ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a" -o
    This
    is
    a
    line

    ================================================================

    参数oP一起使用,会单独打印出要匹配的数字

    [root@zabbix a]# echo office365 | grep -oP 'd+'
    365

    只有参数-P,会完整显示匹配内容的一行,匹配内容高亮显示
    [root@zabbix a]# echo office365 | grep -P 'd+'
    office365

    只有参数-o,不会匹配任何内容,因为没有声明grep要使用正则表达式
    [root@zabbix a]# echo office365 | grep -o 'd+'
    [root@zabbix a]#

    ===============================================================

    12.打印匹配行上下文信息,使用 -A n打印匹配行及其后n行信息。使用-B n打印匹配行及其前n行信息。使用 -C n。打印匹配行及其前后n行信息。假设有多重匹配,将使用--隔离。

    [root@zabbix ~]# seq 1 10 | grep 5
    5
    [root@zabbix ~]# seq 1 10 | grep 5 -A 2
    5
    6
    7
    [root@zabbix ~]# seq 1 10 | grep 5 -A 2 -B 4
    1
    2
    3
    4
    5
    6
    7
    [root@zabbix ~]# seq 1 10 | grep 5 -C 2
    3
    4
    5
    6
    7

    [root@zabbix ~]# echo -e "a b c d a b c d"|grep b -A 1
    b
    c
    --
    b
    c
    [root@zabbix ~]# echo -e "a b c d a b c d"|grep b -B 1
    a
    b
    --
    a
    b
    [root@zabbix ~]# echo -e "a b c d a b c d"|grep b -C 1
    a
    b
    c
    --
    a
    b
    c

    13.-Z选项在输出匹配文件名称时将以/0结尾配合xargs -0能够发挥非常多作用,比如删除匹配某个模式的文件例如以下:

    [root@zabbix a]# echo linux >> a.txt
    [root@zabbix a]# echo linux >> b.txt
    [root@zabbix a]# echo li >> c.txt

    [root@zabbix a]# grep -lZ "linux" *|xargs -0 rm

    [root@zabbix a]# ls
    c.txt

    以上命令将包括linux字符串的a.txt和b.txt删除。

    14.限定全字匹配选项:-w

    [root@zabbix a]# grep -rn "li" *
    a.txt:1:linux
    b.txt:1:linux
    c.txt:1:li
    [root@zabbix a]# grep -rnw "li" *
    c.txt:1:li

    15.-E参数是同时匹配多个关键字

    [root@zabbix a]# cat /etc/passwd|grep -E "root|long"
    root:x:0:0:root:/root:/bin/bash
    operator:x:11:0:operator:/root:/sbin/nologin
    long:x:1002:1002::/home/long:/bin/bash

    grep -E同egrep

    [root@zabbix a]# cat /etc/passwd|egrep "root|lilong"
    root:x:0:0:root:/root:/bin/bash
    operator:x:11:0:operator:/root:/sbin/nologin
    lilong:x:1002:1002::/home/long:/bin/bash

    -e参数同样是匹配多个关键字
    [root@zabbix a]# cat /etc/passwd|grep -e root -e long
    root:x:0:0:root:/root:/bin/bash
    operator:x:11:0:operator:/root:/sbin/nologin
    long:x:1002:1002::/home/long:/bin/bash

    再列一个例子:

    [root@zabbix a]# cat d.txt
    1 5
    2 3
    3 2
    2 3 4
    5
    6
    7

    [root@zabbix a]# grep -E '2|3' d.txt
    2 3
    3 2
    2 3 4
    [root@zabbix a]# egrep '2|3' d.txt
    2 3
    3 2
    2 3 4
    [root@zabbix a]# grep -e 2 -e 3 d.txt
    2 3
    3 2
    2 3 4

  • 相关阅读:
    目标检测应用化之web页面(YOLO、SSD等)
    传统候选区域提取方法
    非极大值抑制(Non-Maximum Suppression,NMS)
    Darknet windows移植(YOLO v2)
    线性判别分析 LDA
    SVM 支持向量机
    特征-相似度衡量
    布隆过滤器 Bloom Filter
    聚类算法
    图论--最大流
  • 原文地址:https://www.cnblogs.com/ultranms/p/9517752.html
Copyright © 2011-2022 走看看