grep 正则表达式说明
来源:互联网 发布:java中获取input标签 编辑:程序博客网 时间:2024/05/19 22:56
首先正则表达式分为三类(man grep可以看到,分别是basic RegExs,extended RegExs,perl RegExs)
则表达式:在计算机科学中,是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串。在很多文本编辑器或其他工具里,正则表达式通常被用来检索和/或替换那些符合某个模式的文本内容。许多程序设计语言都支持利用正则表达式进行字符串操作。例如,在Perl中就内建了一个功能强大的正则表达式引擎。正则表达式这个概念最初是由Unix中的工具软件(例如sed和grep)普及开的。正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。这些是正则表达式的定义。 由于起源于unix系统,因此很多语法规则一样的。但是随着逐渐发展,后来扩展出以下几个类型。了解这些对于学习正则表达式。
一、正则表达式分类:
1、基本的正则表达式(Basic Regular Expression 又叫 Basic RegEx 简称 BREs)
2、扩展的正则表达式(Extended Regular Expression 又叫 Extended RegEx 简称 EREs)
3、Perl 的正则表达式(Perl Regular Expression 又叫 Perl RegEx 简称 PREs)
说明:只有掌握了正则表达式,才能全面地掌握 Linux 下的常用文本工具(例如:grep、egrep、GUN sed、 Awk 等) 的用法
二、Linux 中常用文本工具与正则表达式的关系
常握 Linux 下几种常用文本工具的特点,对于我们更好的使用正则表达式是很有帮助的
- grep , egrep 正则表达式特点:
1)grep 支持:BREs、EREs、PREs 正则表达式
grep 指令后不跟任何参数,则表示要使用 ”BREs“
grep 指令后跟 ”-E" 参数,则表示要使用 “EREs“
grep 指令后跟 “-P" 参数,则表示要使用 “PREs"
2)egrep 支持:EREs、PREs 正则表达式
egrep 指令后不跟任何参数,则表示要使用 “EREs”
egrep 指令后跟 “-P" 参数,则表示要使用 “PREs"
3)grep 与 egrep 正则匹配文件,处理文件方法
a. grep 与 egrep 的处理对象:文本文件
b. grep 与 egrep 的处理过程:查找文本文件中是否含要查找的 “关键字”(关键字可以是正则表达式) ,如果含有要查找的 ”关健字“,那么默认返回该文本文件中包含该”关健字“的该行的内容,并在标准输出中显示出来,除非使用了“>" 重定向符号,
c. grep 与 egrep 在处理文本文件时,是按行处理的
- sed 正则表达式特点
1)sed 文本工具支持:BREs、EREs
sed 指令默认是使用"BREs"
sed 命令参数 “-r ” ,则表示要使用“EREs"
2)sed 功能与作用
a. sed 处理的对象:文本文件
b. sed 处理操作:对文本文件的内容进行 --- 查找、替换、删除、增加等操作
c. sed 在处理文本文件的时候,也是按行处理的
- Awk(gawk)正则表达式特点
1)Awk 文本工具支持:EREs
awk 指令默认是使用 “EREs"
2)Awk 文本工具处理文本的特点
a. awk 处理的对象:文本文件
b. awk 处理操作:主要是对列进行操作
三、常见3中类型正则表达式比较
字符说明Basic RegExExtended RegExpython RegExPerl regEx转义 \\\\^匹配行首,例如'^dog'匹配以字符串dog开头的行(注意:awk 指令中,'^'则是匹配字符串的开始)^^^^$匹配行尾,例如:'^、dog$'匹配以字符串 dog 为结尾的行(注意:awk 指令中,'$'则是匹配字符串的结尾)$$$$^$
匹配空行
^$^$^$^$^string$匹配行,例如:'^dog$'匹配只含一个字符串 dog 的行^string$^string$^string$^string$\<匹配单词,例如:'\<frog' (等价于'\bfrog'),匹配以 frog 开头的单词\<\<不支持不支持(但可以使用\b来匹配单词,例如:'\bfrog')\>
匹配单词,例如:'frog\>'(等价于'frog\b '),匹配以 frog 结尾的单词\>\>不支持不支持(但可以使用\b来匹配单词,例如:'frog\b')\<x\>
匹配一个单词或者一个特定字符,例如:'\<frog\>'(等价于'\bfrog\b')、'\<G\>'\<x\>\<x\>不支持不支持(但可以使用\b来匹配单词,例如:'\bfrog\b'()
匹配表达式,例如:不支持'(frog)'不支持(但可以使用?
匹配前面的子表达式 0 次或 1 次(等价于{0,1}),例如:where(is)?能匹配"where" 以及"whereis"不支持(同\?)???\?匹配前面的子表达式 0 次或 1 次(等价于'\{0,1\}'),例如:'where{n}
n 必须是一个 0 或者正整数,匹配子表达式 n 次,例如:zo{2}能匹配不支持(同\{n\}){n}{n}{n}{n,}"zooz",但不能匹配 "Bob"n 必须是一个 0 或者正整数,匹配子表达式大于等于 n次,例如:go{2,}不支持(同\{n,\}){n,}{n,}{n,}{n,m}能匹配 "good",但不能匹配 godm 和 n 均为非负整数,其中 n <= m,最少匹配 n 次且最多匹配 m 次 ,例如:o{1,3}将配"fooooood" 中的前三个 o(请注意在逗号和两个数之间不能有空格)不支持(同\{n,m\}){n,m}{n,m}{n,m}x|y
匹配 x 或 y,例如: 不支持'z|(food)' 能匹配 "z" 或"food";'(z|f)ood' 则匹配"zood" 或 "food"不支持(同x\|y)x|yx|yx|y[0-9]
匹配从 0 到 9 中的任意一个数字字符(注意:要写成递增)[0-9][0-9][0-9][0-9][xyz]
字符集合,匹配所包含的任意一个字符,例如:'[abc]'可以匹配"lay" 中的 'a'(注意:如果元字符,例如:. *等,它们被放在[ ]中,那么它们将变成一个普通字符)[xyz][xyz][xyz][xyz][^xyz]
负值字符集合,匹配未包含的任意一个字符(注意:不包括换行符),例如:'[^abc]' 可以匹配 "Lay" 中的'L'(注意:[^xyz]在awk 指令中则是匹配未包含的任意一个字符+换行符)[^xyz][^xyz][^xyz][^xyz][A-Za-z]匹配大写字母或者小写字母中的任意一个字符(注意:要写成递增)[A-Za-z][A-Za-z][A-Za-z][A-Za-z][^A-Za-z]匹配除了大写与小写字母之外的任意一个字符(注意:写成递增)[^A-Za-z][^A-Za-z][^A-Za-z][^A-Za-z]\d
匹配从 0 到 9 中的任意一个数字字符(等价于 [0-9])不支持不支持\d\d\D
匹配非数字字符(等价于 [^0-9])不支持不支持\D\D\S匹配任何非空白字符(等价于[^\f\n\r\t\v])不支持不支持\S\S\s匹配任何空白字符,包括空格、制表符、换页符等等(等价于[ \f\n\r\t\v])不支持不支持\s\s\W匹配任何非单词字符 (等价于[^A-Za-z0-9_])
\W\W\W\W\w匹配包括下划线的任何单词字符(等价于[A-Za-z0-9_])\w\w\w\w\B匹配非单词边界,例如:'er\B' 能匹配 "verb" 中的'er',但不能匹配"never" 中的'er'\B\B\B\B\b
匹配一个单词边界,也就是指单词和空格间的位置,例如: 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的'er'\b\b\b\b\t匹配一个横向制表符(等价于 \x09和 \cI)不支持不支持\t\t\v匹配一个垂直制表符(等价于 \x0b和 \cK)不支持不支持\v\v\n匹配一个换行符(等价于 \x0a 和\cJ)不支持不支持\n\n\f匹配一个换页符(等价于\x0c 和\cL)不支持不支持\f\f\r匹配一个回车符(等价于 \x0d 和\cM)不支持不支持\r\r\\匹配转义字符本身"\"\\\\\\\\\cx
匹配由 x 指明的控制字符,例如:\cM匹配一个Control-M 或回车符,x 的值必须为A-Z 或 a-z 之一,否则,将 c 视为一个原义的 'c' 字符不支持不支持 \cx\xn
匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长,例如:'\x41' 匹配 "A"。'\x041' 则等价于'\x04' & "1"。正则表达式中可以使用 ASCII 编码不支持不支持 \xn\num
匹配 num,其中 num是一个正整数。表示对所获取的匹配的引用不支持\num\num [:alnum:]匹配任何一个字母或数字([A-Za-z0-9]),例如:'[[:alnum:]] '[:alnum:][:alnum:][:alnum:][:alnum:][:alpha:]匹配任何一个字母([A-Za-z]), 例如:' [[:alpha:]] '[:alpha:][:alpha:][:alpha:][:alpha:][:digit:]匹配任何一个数字([0-9]),例如:'[[:digit:]] '[:digit:][:digit:][:digit:][:digit:][:lower:]匹配任何一个小写字母([a-z]), 例如:' [[:lower:]] '[:lower:][:lower:][:lower:][:lower:][:upper:]匹配任何一个大写字母([A-Z])[:upper:][:upper:][:upper:][:upper:][:space:]任何一个空白字符: 支持制表符、空格,例如:' [[:space:]] '[:space:][:space:][:space:][:space:][:blank:]空格和制表符(横向和纵向),例如:'[[:blank:]]'ó'[\s\t\v]'[:blank:][:blank:][:blank:][:blank:][:graph:]任何一个可以看得见的且可以打印的字符(注意:不包括空格和换行符等),例如:'[[:graph:]] '[:graph:][:graph:][:graph:][:graph:][:print:]任何一个可以打印的字符(注意:不包括:[:cntrl:]、字符串结束符'\0'、EOF 文件结束符(-1), 但包括空格符号),例如:'[[:print:]] '[:print:][:print:][:print:][:print:][:cntrl:]
任何一个控制字符(ASCII 字符集中的前 32 个字符,即:用十进制表示为从 0 到31,例如:换行符、制表符等等),例如:' [[:cntrl:]]'[:cntrl:]
[:cntrl:]
[:cntrl:]
[:cntrl:]
[:punct:]任何一个标点符号(不包括:[:alnum:]、[:cntrl:]、[:space:]这些字符集)[:punct:][:punct:][:punct:][:punct:][:xdigit:]任何一个十六进制数(即:0-9,a-f,A-F)[:xdigit:][:xdigit:][:xdigit:][:xdigit:]- grep 正则表达式说明
- grep 正则表达式
- 正则表达式之grep
- grep 与正则表达式
- UNIX:grep正则表达式
- 【转】grep正则表达式
- 正则表达式之grep
- 正则表达式在grep
- Grep,正则表达式
- grep 与正则表达式
- 正则表达式之grep
- grep正则表达式
- 正则表达式之grep
- grep 与正则表达式
- @正则表达式---grep@
- grep正则表达式
- 正则表达式之grep
- grep 与正则表达式
- 数组创建Eigen矩阵
- 将url 进行md5加密 转成字符串 参考 百度知道
- 程序员的性格真的内向吗?
- 综合开发_github的SSH的生成
- 自定义Dialog实现各种效果
- grep 正则表达式说明
- HDU 1014 Uniform Generator GCD水题
- 市场急需的前端工程师基本技能
- SQL Server 根据分隔符依次截取每个子字符串
- struct和class的区别 观察者模式 https连接 点击button收到点击事件,中间发生了什么?4道过滤菜鸟的iOS面试题
- 四元素姿态解算 ---地磁计融合解读
- tornado 12、生产模式部署到服务器过程中遇到的一些命令
- Modbus TCP和Modbus Rtu的区别
- osiii的调度点