grep 正则表达式

简介:

 1.作用

Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户

 
  1. 正则表达式主要参数: 
  2. ^        行首定位符 
  3. $        行尾定位符 
  4. ?        匹配任意单个字符 
  5. *        匹配0或多个前一字符 
  6. []       匹配一组字符中的任意一个(单个字符) 
  7. [^]      匹配不在指定字符组内的字符 
  8. \<       词首定位符 
  9. \>       词尾定位符 
  10. \(..\)   标记匹配的字符 
  11. \{ \}    重复出现的次数.  \{m\} \{m,\} {\m,n\} 
  12. [[:alpha:]] 匹配字母    即[a-zA-Z] 
  13. [[:upper:]] 匹配大写字母  即[A-Z] 
  14. [[:lower:]] 匹配小写字母  即[a-z] 
  15. [[:digit:]] 匹配数字    即[0-9] 
  16. [[:alnum:]] 匹配数字与字母 即[0-9a-zA-Z] 
  17. [[:space:]] 匹配空格或tab键    
  18. [[:graph:]] 非空格 
2.格式
grep [options] 
3.主要参数
 
 
  1. [options]主要参数: 
  2. -NUM    :同时显示匹配行的上下NUM行 
  3. -c   :只输出匹配行的计数 
  4. -i   :不区分大小写 
  5. -h   :查询多文件时不显示文件名 
  6. -l   :查询多文件时只输出包含匹配字符的文件名 
  7. -n   :显示匹配行及行号 
  8. -s   :不显示不存在或无匹配文本的错误信息 
  9. -v   :反检索,显示不包含匹配文本的所有行 
  10. -r   :递归查询 
  11. -E   :扩展(同egrep) 
  12. --color :高亮显示匹配到的关键字 
 
 
  1. [root@rhel5 data]# grep -2 xyz keyword               #显示包含xyz的行并同时显示其上下两行 
  2. [root@rhel5 data]# grep xyz keyword*                    #显示所有以keyword开头的文件中包含xyz的行 
  3. [root@rhel5 data]# grep xyz keyword1 keyword2 keyword3  #显示文件keyword1 keyword2 keyword3中包含xyz的行 
  4. [root@rhel5 data]# grep -c xyz keyword               #显示keyword文件中包含xyz的行的个数 
  5. [root@rhel5 data]# grep -h xyz keyword*              #显示所有以keyword开头的文件中包含xyz的行且不显示文件名 
  6. [root@rhel5 data]# grep -l xyz keyword*              #显示所有以keyword开头的文件中包含xyz的文件名 
  7. [root@rhel5 data]# grep -v a keyword                    #显示所有不包含a的行 
  8. [root@rhel5 data]# grep -v "a\|b" keyword               #显示所有不包含a和b的行 
  9. [root@rhel5 data]# grep -vE "a|b" keyword               #同上 
  10.  
  11. [root@rhel5 data]# grep [0-9] keyword                #显示包含数字的行 
  12. [root@rhel5 data]# grep '[a-z]\{4\}' keyword            #显示所有包含每个字符串至少有4个连续小写字母的字符串的行 
  13. [root@rhel5 data]# grep keyword /data/*              #在/data/目录下搜索包含字符串keyword的文件(显示文件的路径与包含keyword的行) 
  14. [root@rhel5 data]# grep -r title /boot/*                #在/boot/目录及子目录下搜索包含字符串title的文件 
  15. [root@rhel5 data]# grep '\<xy' keyword               #显示包含以xy开头的字符串的行(匹配xyz,而不匹配zxy) 
  16. [root@rhel5 data]# grep [[:alnum:]] keyword             #显示包含字母和数字的字符串的行 
  17. [root@rhel5 data]# grep [[:upper:]] keyword             #显示包含大写字母的字符串的行 
 

      本文转自Vnimos51CTO博客,原文链接:http://blog.51cto.com/vnimos/1042705,如需转载请自行联系原作者




相关文章
|
机器学习/深度学习 Shell 开发工具
正则表达式 与文本三剑客(sed grep awk)
正则表达式 与文本三剑客(sed grep awk)
|
运维 Unix Linux
grep正则表达式搜索
grep正则表达式搜索
161 3
|
Unix Linux
如何在 Linux 中使用 Grep 和正则表达式进行文本搜索?
如何在 Linux 中使用 Grep 和正则表达式进行文本搜索?
433 5
|
Linux Perl
[笔记]linux grep之正则表达式
[笔记]linux grep之正则表达式
166 0
|
机器学习/深度学习 NoSQL Linux
Linux行处理工具: grep 正则表达式
Linux行处理工具: grep 正则表达式
209 0
|
机器学习/深度学习 C语言 数据安全/隐私保护
『正则表达式』概念 及在grep、awk、sed、C语言、Python中的简单应用
正则表达式,又称规则表达式,(Regular Expression,在代码中常简写为regex、regexp或RE),是一种文本模式。它可以用来检查一个字符串是否符合某个规则,或者从一个字符串中提取出符合某个规则的子串。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。 正则表达式是由普通字符(例如字符 a 到 z)以及特殊字符(称为"元字符")组成的文字模式。模式描述在搜索文本时要匹配的一个或多个字符串。
|
机器学习/深度学习 移动开发 Go
正则表达式使用说明(包含find命令与grep命令)
正则表达式使用说明(包含find命令与grep命令)
289 0
|
机器学习/深度学习 Linux Perl
Linux三剑客grep、sed、awk以及正则表达式
$ 以...结尾 ^ 以...开头 . 匹配任意一个字符 \- 匹配前一个字符或子表达式任意次(例如:grep "g.*d" a.txt(过滤a.txt文件中的以g开头以d结尾*可以代表有任意多个字符或没有字符))
258 0
Linux三剑客grep、sed、awk以及正则表达式
|
自然语言处理 Shell Perl
Shell正则表达式(grep)
Shell正则表达式(grep)
113 0
|
机器学习/深度学习 Shell Linux