本子战术之正则表明式入门,正则表明式入门

作者: 韦德国际1946国际网址  发布:2019-05-28

   正则表明式(也堪称“regex”或“regexp”)是一种用来叙述文本形式的卓殊语法。在 Linux 系统上,正则表明式日常被用来搜寻文本的方式,以及对文本流实践“搜索-替换”操作以及此外成效。 

摘自:《Linux shell 脚本战略》

awk生于1977年,创办人有七个,分别为 AyrFred Aho,Peter Weinberger, 和 Brian Kernighan,名称源于几个创办者的姓的首字母。

style="font-size: 1陆px">linux下shell脚本学习

韦德国际1946国际网址 ,正则表明式是壹种文本方式,包罗常见字符(比如,a 到 z 之间的字母)和特殊字符(称为“元字符”)。方式描述在检索文本时要合营的二个或多个字符串。

韦德国际1946国际网址 1

作用:拍卖文件文件。

awk的特征是足以对行和列进行操作,输入man awk能够查看awk手册,上面将着重以例子来上学awk语言。

 

上边是正则表达式语法格式大全:

 

语法:

mawk [-W option] [-F value] [-v var=value] [--]  [-W option] [-F value] [-v var=value] [-f program-] [--] [ ...]

字符

说明

将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n”匹配字符“n”。“n”匹配换行符。序列“\”匹配“”,“(”匹配“(”。

^

匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,^ 还会与“n”或“r”之后的位置匹配。

$

匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,$ 还会与“n”或“r”之前的位置匹配。

*

零次或多次匹配前面的字符或子表达式。例如,zo* 匹配“z”和“zoo”。* 等效于 {0,}。

一次或多次匹配前面的字符或子表达式。例如,“zo ”与“zo”和“zoo”匹配,但与“z”不匹配。 等效于 {1,}。

?

零次或一次匹配前面的字符或子表达式。例如,“do(es)?”匹配“do”或“does”中的“do”。? 等效于 {0,1}。

{n}

是非负整数。正好匹配 n 次。例如,“o{2}”与“Bob”中的“o”不匹配,但与“food”中的两个“o”匹配。

{n,}

是非负整数。至少匹配 次。例如,“o{2,}”不匹配“Bob”中的“o”,而匹配“foooood”中的所有 o。“o{1,}”等效于“o ”。“o{0,}”等效于“o*”。

{n,m}

M 和 n 是非负整数,其中 n <= m。匹配至少 n 次,至多 m 次。例如,“o{1,3}”匹配“fooooood”中的头三个 o。'o{0,1}' 等效于 'o?'。注意:您不能将空格插入逗号和数字之间。

?

当此字符紧随任何其他限定符(*、 、?、{n}、{n,}、{n,m})之后时,匹配模式是“非贪心的”。“非贪心的”模式匹配搜索到的、尽可能短的字符串,而默认的“贪心的”模式匹配搜索到的、尽可能长的字符串。例如,在字符串“oooo”中,“o ?”只匹配单个“o”,而“o ”匹配所有“o”。

.

匹配除“n”之外的任何单个字符。若要匹配包括“n”在内的任意字符,请使用诸如“[sS]”之类的模式。

(pattern)

匹配 pattern 并捕获该匹配的子表达式。可以使用 $0…$9 属性从结果“匹配”集合中检索捕获的匹配。若要匹配括号字符 ( ),请使用“(”或者“)”。

(?:pattern)

匹配 pattern 但不捕获该匹配的子表达式,即它是一个非捕获匹配,不存储供以后使用的匹配。这对于用“or”字符 (|) 组合模式部件的情况很有用。例如,'industr(?:y|ies) 是比 'industry|industries' 更经济的表达式。

(?=pattern)

执行正向预测先行搜索的子表达式,该表达式匹配处于匹配 pattern 的字符串的起始点的字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,'Windows (?=95|98|NT|2000)' 匹配“Windows 2000”中的“Windows”,但不匹配“Windows 3.1”中的“Windows”。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。

(?!pattern)

执行反向预测先行搜索的子表达式,该表达式匹配不处于匹配 pattern 的字符串的起始点的搜索字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,'Windows (?!95|98|NT|2000)' 匹配“Windows 3.1”中的 “Windows”,但不匹配“Windows 2000”中的“Windows”。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。

x|y

匹配 x 或 y。例如,'z|food' 匹配“z”或“food”。'(z|f)ood' 匹配“zood”或“food”。

[xyz]

字符集。匹配包含的任一字符。例如,“[abc]”匹配“plain”中的“a”。

[^xyz]

反向字符集。匹配未包含的任何字符。例如,“[^abc]”匹配“plain”中的“p”。

[a-z]

字符范围。匹配指定范围内的任何字符。例如,“[a-z]”匹配“a”到“z”范围内的任何小写字母。

[^a-z]

反向范围字符。匹配不在指定的范围内的任何字符。例如,“[^a-z]”匹配任何不在“a”到“z”范围内的任何字符。

b

匹配一个字边界,即字与空格间的位置。例如,“erb”匹配“never”中的“er”,但不匹配“verb”中的“er”。

B

非字边界匹配。“erB”匹配“verb”中的“er”,但不匹配“never”中的“er”。

cx

匹配 x 指示的控制字符。例如,cM 匹配 Control-M 或回车符。x 的值必须在 A-Z 或 a-z 之间。如果不是这样,则假定 c 就是“c”字符本身。

d

数字字符匹配。等效于 [0-9]。

D

非数字字符匹配。等效于 [^0-9]。

f

换页符匹配。等效于 x0c 和 cL。

n

换行符匹配。等效于 x0a 和 cJ。

r

匹配一个回车符。等效于 x0d 和 cM。

s

匹配任何空白字符,包括空格、制表符、换页符等。与 [ fnrtv] 等效。

S

匹配任何非空白字符。与 [^ fnrtv] 等效。

t

制表符匹配。与 x09 和 cI 等效。

v

垂直制表符匹配。与 x0b 和 cK 等效。

w

匹配任何字类字符,包括下划线。与“[A-Za-z0-9_]”等效。

W

与任何非单词字符匹配。与“[^A-Za-z0-9_]”等效。

xn

匹配 n,此处的 n 是一个十六进制转义码。十六进制转义码必须正好是两位数长。例如,“x41”匹配“A”。“x041”与“x04”&“1”等效。允许在正则表达式中使用 ASCII 代码。

num

匹配 num,此处的 num 是一个正整数。到捕获匹配的反向引用。例如,“(.)1”匹配两个连续的相同字符。

n

标识一个八进制转义码或反向引用。如果 n 前面至少有 n 个捕获子表达式,那么 n 是反向引用。否则,如果 n 是八进制数 (0-7),那么 n 是八进制转义码。

nm

标识一个八进制转义码或反向引用。如果 nm 前面至少有 nm 个捕获子表达式,那么 nm 是反向引用。如果 nm 前面至少有 n个捕获,则 n 是反向引用,后面跟有字符 m。如果两种前面的情况都不存在,则 nm 匹配八进制值 nm,其中 和 m 是八进制数字 (0-7)。

nml

当 n 是八进制数 (0-3),m 和 l 是八进制数 (0-7) 时,匹配八进制转义码 nml

un

匹配 n,其中 n 是以四位十六进制数表示的 Unicode 字符。例如,u00A9 匹配版权符号 (©)。

本子战术之正则表明式入门,正则表明式入门。上边是近乎的表达:

参数-实例:

 

韦德国际1946国际网址 2

1、初识awk

截取top命令部分剧情,拷贝到test.txt里:

[email protected]:~/learn/$  root           200m  49m  11m S         : amosli         534m  21m  12m S         : gnome- mongodb        623m  15m  S         : amosli        1005m 125m  17m S         : root                       S         : kworker/:        
  amosli            R         : amosli         686m   S         : hud- amosli         419m  10m  S         : telepathy- root                       S         : kworker/:        
     root             S         : root                       S         : root                       S         : ksoftirqd/        
     root      RT                 S         : migration/        
     root      RT                 S         : watchdog/         
     root      RT                 S         : migration/

上面打字与印刷第2列的开始和结果,注意pattern里是单引号.

[email protected]:~/learn/$   test.txt 
root
amosli
mongodb
amosli
root
amosli
amosli
amosli
root
root
root
root
root
root
root

$0表示打字与印刷出来全体,$n,n>0时意味着打字与印刷第n列。

 

韦德国际1946国际网址 3

2、拆解awk语句块

先看例子:

[email protected]:~/learn/$   test.txt 

ok,是否用点不太懂?看不太懂没涉及,上边拆解开来,贰个awk脚本平常分为3部分:BEGIN 语句块END语句块和能够使用情势相配的通用语句块。那八个部分是可选的,它们中的任何1个部分都得以不出现在剧本中。脚本平时包蕴在单引号只怕双引号里。其通用形式协会如下所示:

下边是实在常用的语法格式:

   filename  

awk的劳作规律:

(1)、试行BEGIN { commands }语句块中的语句。

(2)、从文件或stdin中读取一行,然后施行pattern { commands }。重复那个历程,直到文件全部被读取达成。

(3)、当读至输入流(input stream)末尾时,实践END { commands } 语句块。

BEGIN语句块在awk开始从输入流中读取行以前被试行。那是2个可选的语句块。

END语句块在awk从输入流中读取完全体的行之后即被实行。这一个同样是可选的。

最根本的一部分正是pattern语句块中的通用命令。这么些一样是可选的。如果不提供该语句块,则暗中认可实行的是{ print },即打字与印刷每贰个读取到的行。awk对于读取到的每壹行,都会施行这一个讲话块.例:

[email protected]:~/learn/$  -e  |  

此地首施夷光行的是BEGIN { print "now start" },然后初阶试行默许打字与印刷line一nline二,最终读完全数的行之后始发试行END语句块{ print "this is end "} 

一样能够将BEGIN和END都去掉,只使用私下认可的打字与印刷方式:

[email protected]:~/learn/$  -e  |  

这种艺术和例1的秘籍则是一律的。学完那八个例证,基本上就明白了awk到底咋用的了,其格式应该是何等,即现已入门了。

本文由韦德国际1946发布于韦德国际1946国际网址,转载请注明出处:本子战术之正则表明式入门,正则表明式入门

关键词: Linux

上一篇:vuex写一个cnode的脚手架,router基本选用
下一篇:没有了