linux系统中grep命令

 

1、测试数据

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t

 

2、匹配特定字符串

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep 5 a.txt
5 q k
[root@PC3 test]# grep "w" a.txt
4 w p
6 w f

 

3、显示特定字符串的前后几行

[root@PC3 test]# grep "5" a.txt
5 q k
[root@PC3 test]# grep -A 2 "5" a.txt  ## 显示匹配5的行及其后两行
5 q k
6 w f
7 x F

 

[root@PC3 test]# grep -B 3 "5" a.txt  ## 显示匹配5的行及其前3行
2 f a
3 x g
4 w p
5 q k

 

[root@PC3 test]# grep -C 2 "5" a.txt  ## 显示匹配5的行及其前后各2行
3 x g
4 w p
5 q k
6 w f
7 x F

 

[root@PC3 test]# grep -A 2 -B 3 "5" a.txt
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F

 

4、grep -w 精确匹配

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep "a" a.txt  ## 提取匹配a的行
1 e abc
2 f a
[root@PC3 test]# grep -w "a" a.txt  ## 精确匹配包含a的行
2 f a

 

5、grep -i 忽略大小写

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep "f" a.txt
2 f a
6 w f
[root@PC3 test]# grep -i "f" a.txt  ## 忽略大小写
2 f a
6 w f
7 x F

 

6、grep同时匹配多个字符

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep "a" a.txt
1 e abc
2 f a
[root@PC3 test]# grep "w" a.txt
4 w p
6 w f
[root@PC3 test]# grep "a\|w" a.txt  ## 同时提取包含a和w的行
1 e abc
2 f a
4 w p
6 w f
[root@PC3 test]# grep -E "a|w" a.txt ## 同时提取包含a和w的行
1 e abc
2 f a
4 w p
6 w f

 

7、 grep反向选择

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep -v "a" a.txt ## 提取不包含a的行
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep -v "a\|w" a.txt  ## 提取不包含a和w的行
3 x g
5 q k
7 x F
8 m y
9 c t

 

8、grep提取以特定字符开头和特定字符结尾的行

[root@PC3 test]# cat a.txt 调整测试数据
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
y t f
[root@PC3 test]# grep "^3" a.txt  ## 提取以3开头的行
3 x g
[root@PC3 test]# grep "^r" a.txt  ## 提取以r开头的行
r 7 3
[root@PC3 test]# grep "^3\|^r" a.txt  ## 同时提取以3和以r开头的行
3 x g
r 7 3
[root@PC3 test]# grep -E "^3|^r" a.txt ## 同时提取以3和以r开头的行
3 x g
r 7 3

 

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
y t f
[root@PC3 test]# grep "a$" a.txt  ## 提取以a结尾的行
2 f a
[root@PC3 test]# grep "3$" a.txt  ## 提取以3结尾的行
r 7 3
[root@PC3 test]# grep "a$\|3$" a.txt  ## 同时提取以a和以3结尾的行
2 f a
r 7 3
[root@PC3 test]# grep -E "a$|3$" a.txt  ## 同时提取以a和以3结尾的行
2 f a
r 7 3

 

9、grep命令统计字符出现的次数

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
y t f
[root@PC3 test]# grep -o "f" a.txt
f
f
f
[root@PC3 test]# grep -o "f" a.txt | wc -l  ## 统计f出现的次数
3
[root@PC3 test]# grep -o "w" a.txt
w
w
[root@PC3 test]# grep -o "w" a.txt | wc -l  ## 统计w出现的次数
2
[root@PC3 test]# grep -o "f\|w" a.txt | wc -l   ## 同时统计f和w出现的次数
5
[root@PC3 test]# grep -E -o "f|w" a.txt | wc -l  ## 同时统计f和w出现的次数
5

 

10、显示字符出现的行数

[root@PC3 test]# cat a.txt
1 e abc
2 f a
3 x g
4 w p
5 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
y t f
[root@PC3 test]# grep -n "a" a.txt ## 显示a出现的行数
1:1 e abc
2:2 f a
[root@PC3 test]# grep -n "f" a.txt ## 显示f出现的行数
2:2 f a
6:6 w f
11:y t f

 

11、检索包含特定字符串的文件

[root@PC3 test]# ls
a.log  b.log  c.log  d.log
[root@PC3 test]# cat a.log
2 3 f
error!
[root@PC3 test]# cat b.log
dsf d
4 5 s
[root@PC3 test]# cat c.log
f error
d f 8
[root@PC3 test]# cat d.log
e f
ERROR
[root@PC3 test]# grep -l "error" *.log  ## 列出包含error字样的文件
a.log
c.log
[root@PC3 test]# grep -i -l "error" *.log ## 忽略大小写,列出包含error字样的文件
a.log
c.log
d.log
[root@PC3 test]# grep -i -L "error" *.log  ## 忽略大小写,列出不包含error字样的文件
b.log

 

12、同时提取以特定字符开头和特定字符结尾的行

[root@PC3 test]# cat a.txt  ## 调整测试数据
1 e abc
3 f a
3 x g
4 w k
4 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
r t f
[root@PC3 test]# grep "^3\|g$" a.txt ## 提取以3开头或者以g结尾的行
3 f a
3 x g
[root@PC3 test]# grep -E "^3|g$" a.txt ## 提取以3开头或者以g结尾的行
3 f a
3 x g
[root@PC3 test]# grep "^3.*g$" a.txt  ## 提取以3开头同时以g结尾的行
3 x g
[root@PC3 test]# grep "^4.*k$" a.txt  ## 提取以3开头同时以k结尾的行
4 w k
4 q k

 

13、grep命令提取以数字或者以字母开头的行

[root@PC3 test]# cat a.txt
1 e abc
3 f a
3 x g
4 w k
4 q k
6 w f
7 x F
8 m y
9 c t
r 7 3
r t f
[root@PC3 test]# grep "^[0-9]" a.txt  ## 提取以数字开头的行
1 e abc
3 f a
3 x g
4 w k
4 q k
6 w f
7 x F
8 m y
9 c t
[root@PC3 test]# grep "^[a-z]" a.txt  ## 提取以字母开头的行,大写字母的话为[A-Z]
r 7 3
r t f
[root@PC3 test]# grep "[0-9]$" a.txt  ## 提取以数字结尾的行
r 7 3
[root@PC3 test]# grep "[a-z]$" a.txt  ## 提取以字母结尾的行
1 e abc
3 f a
3 x g
4 w k
4 q k
6 w f
8 m y
9 c t
r t f

 

14、grep命令指定匹配字符的开头以及结尾

[root@PC3 test]# cat a.txt
1 abc 45
w xabc 53
8 xabcd 54
[root@PC3 test]# grep "abc" a.txt
1 abc 45
w xabc 53
8 xabcd 54
[root@PC3 test]# grep "\<abc" a.txt  ## 匹配以abc开头的字符
1 abc 45
[root@PC3 test]# grep "abc\>" a.txt  ## 匹配以abc结尾的字符
1 abc 45
w xabc 53
[root@PC3 test]# grep "\<abc\>" a.txt  ## 匹配同时以abc开头和以abc结尾的字符
1 abc 45

 

15、grep命令剔除空行

[root@PC3 test]# cat a.txt 测试数据
1 abc 45
w xabc 53


8 xabcd 54
[root@PC3 test]# cat -A a.txt
1 abc 45$
w xabc 53$
$
  $
8 xabcd 54$
[root@PC3 test]# sed -n l a.txt
1 abc 45$
w xabc 53$
$
  $
8 xabcd 54$

 

[root@PC3 test]# cat a.txt
1 abc 45
w xabc 53


8 xabcd 54
[root@PC3 test]# cat -A a.txt  ## a.txt中包含绝对的空行和以空格形式存在的空行
1 abc 45$
w xabc 53$
$
  $
8 xabcd 54$
[root@PC3 test]# nl -b a a.txt  ## 查看行号
     1  1 abc 45
     2  w xabc 53
     3
     4
     5  8 xabcd 54
[root@PC3 test]# grep -v "^$" a.txt  ## 剔除空行
1 abc 45
w xabc 53

8 xabcd 54
[root@PC3 test]# grep -n -v "^$" a.txt  ## 仅剔除了第三行,说明grep可以剔除绝对的空行,不能剔除以空格存在的空行
1:1 abc 45
2:w xabc 53
4:
5:8 xabcd 54

 

[root@PC3 test]# nl -b a a.txt
     1  1 abc 45
     2  w xabc 53
     3
     4
     5  8 xabcd 54
[root@PC3 test]# awk NF a.txt ## 剔除所有空行
1 abc 45
w xabc 53
8 xabcd 54
[root@PC3 test]# sed '/^[\t ]*$/d' a.txt  ## 剔除所有空行
1 abc 45
w xabc 53
8 xabcd 54

 

16、匹配整行为特定字符的行

[root@PC3 test]# cat a.txt
1 abc 45
w xabc 53
a
8 xabcd 54
[root@PC3 test]# grep "a" a.txt
1 abc 45
w xabc 53
a
8 xabcd 54
[root@PC3 test]# grep -x "a" a.txt  ## 只有整行为a的行才会显示
a

 

17、匹配包含连续若干数字或者字母的行

[root@PC3 test]# cat a.txt
1 abc 44325565
w xabc 5344
a
8 xabcd 54
[root@PC3 test]# grep "[0-9]\{2\}" a.txt  ## 提取包含2个连续数字的行
1 abc 44325565
w xabc 5344
8 xabcd 54
[root@PC3 test]# grep "[0-9]\{3\}" a.txt  ## 提取至少包含3个连续数字的行
1 abc 44325565
w xabc 5344
[root@PC3 test]# grep "[0-9]\{4\}" a.txt  ## 4个
1 abc 44325565
w xabc 5344
[root@PC3 test]# grep "[0-9]\{5\}" a.txt  ## 5个
1 abc 44325565

 

[root@PC3 test]# cat a.txt
1 abc 44325565
w xabc 5344
a
8 xabcd 54
[root@PC3 test]# grep "[a-z]\{2\}" a.txt  ## 至少包含2个连续字母的行
1 abc 44325565
w xabc 5344
8 xabcd 54
[root@PC3 test]# grep "[a-z]\{3\}" a.txt  ## 3个
1 abc 44325565
w xabc 5344
8 xabcd 54
[root@PC3 test]# grep "[a-z]\{4\}" a.txt ## 4个
w xabc 5344
8 xabcd 54
[root@PC3 test]# grep "[a-z]\{5\}" a.txt  ## 5个
8 xabcd 54

 

18、grep命令同时提取包含多个字符串的行

[root@PC3 test]# cat a.txt
e 8 f
s e g
s g 3
d g w
a g e
3 t r
[root@PC3 test]# grep "g" a.txt
s e g
s g 3
d g w
a g e
[root@PC3 test]# grep "g" a.txt | grep "e"
s e g
a g e
[root@PC3 test]# grep "g" a.txt | grep "e" | grep "a"   ## 提取同时包含a、g和e的行
a g e

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


系ubuntu 下面打开终端输入:sudo apt-get install sendmail一般就安装完成噶啦跟住进入 /etc/mail/目录输入:m4 sendmail.mc &gt; sendmail.cf意思系跟住.mc文件 生成 sendmial.cf文件输入呢个命令:ps aux | g
依家我有1个软件goagent目录(大家懂得) 放在/home/gateman/Programs/ 下 1. proxy.py 入面有1个 proxy.py 文件 放在/home/gateman/Programs/goagent/local/ 入面 2.breakwall.sh 我在 proxy.p
其实我想讲的是 cp -L关于-L参数的解释:-L, --dereference always follow symbolic links in SOURCE意思是如果复制目标是1个软链接,则复制链接的目标 不是链接本身做个例子: 例如 ~/tmp/fo1 入面有1个c.txt 文件 和 指向他的软
原地址:http://www.rjgc.net/control/content/content.php?nid=4418 1、将文件checkout到本地目录svn checkout path(path是服务器上的目录)例如:svn checkout svn://192.168.1.1/pro/do
chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以 `/`,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为 `/` 位置。实例:用live CD ubuntu假设你的
简单解析下, stdin就是标准输入, stdout就是标准。举个例子, 在当前我要打包1个文件夹 /var/log/ 到当前目录下,并用zip压缩,那么我们可以分步执行#tar -cvf log.tar /var/log/#zip -r log.tar.zip log.tar#rm -rf log
转自:http://man.ddvip.com/linux/Mandrakelinuxref/process-priority.html系统中运行的每个进程都有一个优先级(亦称“nice 值”),其范围从 -20 (最高优先级)到 19 (最低优先级)。默认情况下,进程的优先级是 0 (“基本”调度
str=&quot;/home/gateman&quot; if [ ${str:0:1} = &quot;/&quot; ]; then echo &quot;yes&#39;fi ${str:0:1} 中0表示从第几个字符开始,1表示截取多长
转自:http://kwokchivu.blog.51cto.com/1128937/694347 在RedHat系统下用usermod 命令可把某用户添加进多个附属组,默认情况下,一次性添加多个附属组可用以下方式来添加: usermod -G 附属组1,附属组2,...,附属组X 用户名 但在添加
有个文件 test.txt 内容如下:bash-3.00$ cat test.txt user user user_hiuser #注:呢行系空行T JGATEMANGATTTTTEMANGABBEMANAAABbash-3.00$下面介绍下常用的通配符 配合grep 命令:1. &quot;.&q
linux系统为每1个文件都分配有i索引节点(inode),系统根据呢d节点从磁盘找出数据。 一般来讲,每1个文件名(包含全路径)实际上都链接住1个i索引节点。inode实际上系乜咧? 其实可以算系1个指向磁盘具体位置(柱面,扇区之类)的指针, 系统分析某个文件的inode,得出磁盘柱面,扇区等数据
grep 可以立即为筛选, 一般的用法系 grep + 要查询的字段 + 文件(或者内容 例如| 传递既内容)1.grep + 要查询的字段 + 文件gateman@GPC:~/shell/SQL_GSI$ grep OID a.sqlWHERE OID=@BuildNOWHERE OID INWH
原文转自:http://www.ibm.com/developerworks/cn/linux/l-cn-vimcolumn/index.html开始之前人类大脑对文字的处理是平面式的,所以我们浏览文章、查找资料或者重构代码,要么是横向读,要么是纵向读,要么使用搜索功能,将文字作为一个平面整体。而在
PS:偶很喜欢用scp这个命令来传输数据。scp命令跟cp命令类似,只不过cp命令是在同一台机器上用的,scp是在两台机器上复制传输数据的命令。scp实质相当于利用SSH协议来传输数据的cp命令。 用法举例: 1、复制远程服务器的文件到本地: scp -P888 root@120.18.50.33:
打开终端,进入/bin/ls 一下会见到 bash sh 呢两个文件。其实距地系两个唔同既shell 解析器。如果在脚本a.sh 开头写入#!/bin/sh那么执行./a.sh 时候 就相当于 sh a.sh同理 开头写入#!/bin/bash执行./a.sh 时候 就相当于 bash a.sh如果
find查找文件的时候排除某个或几个文件或目录转自:http://www.cnblogs.com/starspace/archive/2008/10/20/1315380.html比如要在/usr/sam目录下查找不在dir1子目录之内的所有文件find /usr/sam -path &quot;/
假设有变量 var=http://www.google.com/test.htm一 # 号截取,删除左边字符,保留右边字符。echo ${var#*//}其中 var 是变量名,# 号是运算符,*// 表示从左边开始删除第一个 // 号及左边的所有字符即删除 http://结果是 :www.goog
转自: http://edyfox.codecarver.org/html/_vimrc_for_beginners.htmlVIM 中可供用户定制的选项非常非常多,作为初学者,我们没有必要了解这么多东西。下面,滇狐简单列出了一些最常用的配置项,大家可以根据自己的需要将这些内容添加到自己的 .vim
转自:http://www.einit.com/user1/11/archives/2006/3603.htmlUnix/Linux下一般想让某个程序在后台运行,很多都是使用 &amp; 在程序结尾来让程序自动运行。比如我们要运行mysql在后台: /usr/local/mysql/bin/mysq
首先, mount是类unix系统, 挂载设备到1个文件夹的操作命令, 注意系设备阿正常来讲,mount 是不能挂在文件夹到文件夹的。例如, 在我的~/tmp/ 目录中有两个文件夹fo1 fo2其中fo1 中有3个文件a.txt b.txt c.txt fo2 有4个 e.txt d.txt e.t