Chinaunix首页 | 论坛 | 博客
  • 博客访问: 962356
  • 博文数量: 376
  • 博客积分: 154
  • 博客等级: 入伍新兵
  • 技术积分: 1558
  • 用 户 组: 普通用户
  • 注册时间: 2011-10-13 08:42
文章分类

全部博文(376)

文章存档

2014年(11)

2013年(88)

2012年(260)

2011年(17)

分类:

2012-08-30 13:28:59

原文地址:linux grep命令的使用总结 作者:zhdrfirst

1、功能描述

grep 命令在一个或多个文件中查找与指定模式匹配的字符串。如果模式里包含有空格,必须用引号括起来。grep的模式只能是一个被引号括起来的字符串或者是一个单词,后面紧跟着的参数都被当作文件名。grep命令把结果输出到标准输出上,并不改变被搜索的源文件。

2、命令格式
grep [选项] pattern filename1 filename2 ...

3、主要参数
[options]主要参数:

选项功能
-b在每一行前面加上其所在的块号,根据上下文定位磁盘块时可能会用到。
-c显示匹配到的行的数目,而不显示行的内容
-h不显示文件名
-i比较字符的时候忽略大小写的区别
-l只列出匹配行所在文件的文件名(每个文件名只列一次),文件名之间用换行符分隔。
-n在每一行前面加上它在文件中的相对行号
-s无声操作,即只显示报错信息,以检查退出状态
-v反向查找,只显示不匹配的行
-w全字匹配

grep –n  ‘^south’ datafile   ----- 选项-n在找到指定模式的行前面加上其行号在一并输出

grep –i  ‘pat’ datafile   ----- 选项-i 关闭大小写敏感性,表达式pat包含任意大小写的组合都符合

grep –v ‘test’ datafile -----查找所有不包含test的行

grep –l ‘test’ *    ----- 查询输出当前目录下所有包含test的文件名

4、支持的正则表达式元字符

元字符功能实例匹配结果备注
^行首定位符grep “^test” datafile打印所有以test开头的行 
$行尾定位符grep “test$” datafile打印所有以test结尾的行 
.  (点)匹配除“/n”之外的任何单个字符/t..t/匹配包含一个t,后跟两个字符,在跟一个t的行。定位.本身只需加上转义符即可
*零次或多次匹配前面的字符或子表达式/t*est/匹配包含0个或者多个t后跟est的行。可以匹配:est、test、ttest 
[]匹配一组字符中的任一个/[Tt]est/匹配包含Test或者test行 
[^]匹配不在指定组内的字符/[^A-Z]/匹配不在范围A至Z之间的任一个字符 
/<词首定位符//匹配包含以love开头的词的行。如:love、lovergrep “/打印所有包含以north开头的单词的行。
/>词尾定位符/love/>/匹配包含以love结尾的词的行。 
如:aalove
grep “north/>” datafile 
打印所有包含以north结尾的单词的行。
/(pattern/)匹配模式pattern,并将之存储在寄存器中,供之后使用。//(love/)able /1r/最多可以使用9个标签,模式中最左边的标签是第一个。例如:模式love被保存为标签1,用/1表示。左边这个例子中,查找串是一个loveable 后跟 lover的长串。sed、vi、grep支持。 
例如: 
sed “s//(love/)//1able/” 功能是将文件中的love替换成loveable。
x/{m/} 或 
x/{m,/} 或 
x/{m,n/}
\


字符x的重复出现; 
m次,至少m次,至少m次且不超过n次。
转义字符

o/{5,10/}匹配包含5-10个连续的字母o的行。vi和gre





阅读(463) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~