grep中使⽤d匹配数字不成功的原因解决
⾸先正则表达式分为三类(man grep可以看到,分别是basic RegExs,extended RegExs,perl RegExs)
正则表达式:在计算机科学中,是指⼀个⽤来描述或者匹配⼀系列符合某个句法规则的字符串的单个字符串。在很多⽂本编辑器或其他⼯具⾥,正则表达式通常被⽤来检索或替换那些符合某个模式的⽂本内容。正则表达式这个概念最初是由Unix中的⼯具软件(例如sed和grep)普及开的。
⼀、正则表达式分类:
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
RegEx
Extended
RegEx
python
RegEx
Perl regEx
转义\\\\
^匹配⾏⾸,例如'^dog'匹配以字符串dog开头的⾏(注意:awk
指令中,'^'则是匹配字符串的开始)
^^^^
$匹配⾏尾,例如:'^、dog$'匹配以字符串 dog 为结尾的⾏(注
意:awk 指令中,'$'则是匹配字符串的结尾)
$$$$
^$匹配空⾏^$^$^$^$
^string$匹配⾏,例如:'^dog$'匹配只含⼀个字符串 dog 的⾏^string$^string$^string$^string$
\<;匹配单词,例如:'\<frog' (等价于'\bfrog'),匹配以 frog 开头的单词\<\<;不⽀持
不⽀持(但
可以使⽤\b来
匹配单词,
例
如:'\bfrog')
\>匹配单词,例如:'frog\>'(等价于'frog\b '),匹配以 frog 结尾的单词\>\>不⽀持
不⽀持(但
可以使⽤\b来
python正则表达式不包含匹配单词,
例
如:'frog\b')
\<x\>匹配⼀个单词或者⼀个特定字符,例如:'\<frog\>'(等价于'\bfrog\b')、'\<G\>'\<x\>\<x\>不⽀持
不⽀持(但
可以使⽤\b来
匹配单词,
例
如:'\bfrog\b'
()匹配表达式,例如:不⽀持'(frog)'不⽀持
(但可
以使⽤\
(\),
如:\
(dog\)
()()()
\(\)匹配表达式,例如:不⽀持'(frog)'\(\)不⽀持(同())不⽀持
(同())不⽀持(同())
匹配前⾯的⼦表达式 0 次或 1 次(等价于{0,1}),例如:where(is)?能匹配"where" 以及"whereis"不⽀持
(同\?)
???
\?匹配前⾯的⼦表达式 0 次或 1 次(等价于'\{0,1\}'),例如:'where\(is\)\? '能匹配 "where"以及"whereis"\?不⽀持(同?)不⽀持
(同?)
不⽀持(同?)
当该字符紧跟在任何⼀个其他限制符(*, +, ?, {n},{n,}, {n,m})
后⾯时,匹配模式是⾮贪婪的。⾮贪婪模式尽可能少的匹配所
搜索的字符串,⽽默认的贪婪模式则尽可能多的匹配所搜索的
字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个"o",⽽
'o+' 将匹配所有 'o'
不⽀持不⽀持不⽀持不⽀持
.匹配除换⾏符('\n')之外的任意单个字符(注意:awk 指令中的句点能匹配换⾏符).
.(如果要匹配
包括“\n”在内的
任何⼀个字
符,请使
⽤:'(^$)|(.)
.
.(如果要匹
配包括“\n”在
内的任何⼀
个字符,请
使⽤:' [.\n] '
*匹配前⾯的⼦表达式 0 次或多次(等价于{0, }),例如:zo* 能
匹配 "z"以及 "zoo"
****
\+匹配前⾯的⼦表达式 1 次或多次(等价于'\{1, \}'),例如:'where\(is\)\+ '能匹配 "whereis"以及"whereisis"\+不⽀持(同+)不⽀持
(同+)
不⽀持(同+)
+匹配前⾯的⼦表达式 1 次或多次(等价于{1, }),例如:zo+能匹配 "zo"以及 "zoo",但不能匹配 "z"不⽀持
(同\+)
+++
{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|y x|y x|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匹配⼀个横向制表符(等价于 09和 \cI)不⽀持不⽀持\t\t \v匹配⼀个垂直制表符(等价于 0b和 \cK)不⽀持不⽀持\v\v \n匹配⼀个换⾏符(等价于 0a 和\cJ)不⽀持不⽀持\n\n \f匹配⼀个换页符(等价于 0c 和\cL)不⽀持不⽀持\f\f \r匹配⼀个回车符(等价于 0d 和\cM)不⽀持不⽀持\r\r \\匹配转义字符本⾝"\"\\\\\\\\
\cx 匹配由 x 指明的控制字符,例如:\cM匹配⼀个Control-M 或回
车符,x 的值必须为A-Z 或 a-z 之⼀,否则,将 c 视为⼀个原义
的 'c' 字符
不⽀持不⽀持\cx
n匹配 n,其中 n 为⼗六进制转义值。⼗六进制转义值必须为确
定的两个数字长,例如:' 41' 匹配 "A"。' 041' 则等价于' 04' &
"1"。正则表达式中可以使⽤ ASCII 编码
不⽀持不⽀持n
\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中使⽤"\d"匹配数字不成功的原因解决的⽂章就介绍到这了,更多相关grep "\d"匹配数字内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论