参数

  • -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\n2\n3\n4"
1
2
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v "[1]"
2
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v "[1-2]"
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v -E "[1-2]"
3
4

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

[root@zabbix net]# echo -e "1\n2\n3\n4"|grep "[1,2]" -c
2

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

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

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

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

[root@zabbix net]# echo -e "11111\n222"|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\n222"|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 "\nline.123\nline."|grep -P "[a-z]*\.\d+"
line.123
[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "[a-z]*\."
line.123
line.
[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "[a-z]*\.$"
line.
[root@zabbix net]# echo -e "\nline.123\nline."|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\nb\nc\nd\na\nb\nc\nd"|grep b -A 1
b
c
--
b
c
[root@zabbix ~]# echo -e "a\nb\nc\nd\na\nb\nc\nd"|grep b -B 1
a
b
--
a
b
[root@zabbix ~]# echo -e "a\nb\nc\nd\na\nb\nc\nd"|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

linux下grep命令详解的更多相关文章

  1. Linux下ps命令详解 Linux下ps命令的详细使用方法

    http://www.jb51.net/LINUXjishu/56578.html Linux下的ps命令比较常用 Linux下ps命令详解Linux上进程有5种状态:1. 运行(正在运行或在运行队列 ...

  2. Linux下rar命令详解

    Linux下rar命令详解 用法: rar <命令> -<选项1> ….-<选项N> < 操作文档> <文件…> <@文件列表…> ...

  3. linux下tar命令详解

     linux下tar命令详解    tar是Linux环境下最常用的备份工具之一.tar(tap archive)原意为操作磁带文件,但基于Linux的文件操作机制,同样也可适用于普通的磁盘文件.ta ...

  4. Linux下chkconfig命令详解(转)

    Linux下chkconfig命令详解 chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. ...

  5. Linux知识积累(4) Linux下chkconfig命令详解

    Linux下chkconfig命令详解 chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. ...

  6. Linux下top命令详解

    Linux下top命令详解 top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.top是一个动态显示过程,即可以通过用户按键来不断刷 ...

  7. 转载的 Linux下chkconfig命令详解

    Linux下chkconfig命令详解 chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. ...

  8. 转 linux下cat命令详解

    linux下cat命令详解 http://www.cnblogs.com/perfy/archive/2012/07/23/2605550.html 简略版: cat主要有三大功能:1.一次显示整个文 ...

  9. Linux下svn命令详解

    本文主要是说明linux下svn命令的使用方法,同时记录自己在使用中遇到的一些疑惑. 1.Linux命令行下将文件checkout到本地目录 svn checkout url(url是服务器上的目录) ...

随机推荐

  1. d3.select(this)不能用箭头函数

    d3中典型的数据绑定片段 const items = svg.selectAll('g') .data(gdfs,(d)=> d.name); const enter = items.enter ...

  2. 最全的SpringCloud视频教程

    史上最全的SpringCloud视频教程 转自:https://blog.csdn.net/itmayeidu/article/details/79426589 史上最全的SpringCloud视频教 ...

  3. PHP数组合并和去重的函数有哪些

    PHP数组合并和去重的函数有哪些 一.总结 一句话总结:合并:array_merge() array_merge_recursive() +号:去重:array_flip() array_unique ...

  4. ubuntu解压和压缩文件

    .tar 解包:tar xvf FileName.tar打包:tar cvf FileName.tar DirName(注:tar是打包,不是压缩!)———————————————.gz解压1:gun ...

  5. Yii2给数据库表添加字段后对应模型无法识别到该属性的原因和解决办法

    Yii2给数据库表添加字段后对应模型无法识别到该属性的原因和解决办法 应为数据库表的结构被缓存了.删除runtime文件夹或者执行 //清理指定表结构缓存数据 Yii::$app->db-> ...

  6. ado.net常用操作

    目录 一.ADO.NET概要 二.ADO.NET的组成 三.Connection连接对象 3.1.连接字符串 3.1.1.SQL Server连接字符串 3.1.2.Access连接字符串 3.1.3 ...

  7. GEO数据下载分析(SRA、SRR、GEM、SRX、SAMN、SRS、SRP、PRJNA全面解析)

    很多时候我们需要从GEO(https://www.ncbi.nlm.nih.gov/geo/)下载RNA-seq数据,一个典型的下载页面是https://www.ncbi.nlm.nih.gov/ge ...

  8. 使用validate()方法进行输入校验 --Struts2框架

    服务器端的输入校验包含两种方式:硬编码方式和配置文件方式.本文演示硬编码方式中使用validate()方法进行输入校验. 1.项目目录结构: 2.项目核心代码: BookAction.java: pu ...

  9. 浅谈微服务架构、容器技术与K8S

    关注嘉为科技,获取运维新知 企业应用系统:从单体应用走向微服务架构:从裸金属走向容器. 如果在诸多热门云计算技术诸如容器.微服务.DevOps.OpenStack等之中,找出一个最火的方向,那么可能非 ...

  10. 新项目的vue组件

    项目地址:http://pan.baidu.com/s/1qYIxCXu 很久没有写博客的原因的是之前一直在解决一个问题,这个问题就是:我们在写组件的时候,官方推荐把css写在组件里面,但是如果我们写 ...