当前位置: 首页 > 文档资料 > Awk 中文教程 >

正则表达式( Regular Expressions)

优质
小牛编辑
135浏览
2023-12-01

AWK在处理正则表达式方面非常强大和高效。 使用简单的正则表达式可以解决许多复杂的任务。 任何命令行专家都知道正则表达式的强大功能。

本章介绍了带有合适示例的标准正则表达式。

Dot

它匹配除行尾字符之外的任何单个字符。 例如,以下示例匹配fin, fun, fan等。

例子 (Example)

[jerry]$ echo -e "cat\nbat\nfun\nfin\nfan" | awk '/f.n/'

执行上面的代码时,您会得到以下结果 -

输出 (Output)

fun
fin
fan

开始行

它匹配行的开头。 例如,以下示例打印以模式The开头的所有行。

例子 (Example)

[jerry]$ echo -e "This\nThat\nThere\nTheir\nthese" | awk '/^The/'

执行此代码时,您将获得以下结果 -

输出 (Output)

There
Their

行结束

它匹配行尾。 例如,以下示例打印以字母n结尾的行。

例子 (Example)

[jerry]$ echo -e "knife\nknow\nfun\nfin\nfan\nnine" | awk '/n$/'

输出 (Output)

执行此代码时,您将获得以下结果 -

fun
fin
fan

匹配字符集

它仅用于匹配多个字符中的一个。 例如,以下示例匹配模式CallTall但不匹配Ball

例子 (Example)

[jerry]$ echo -e "Call\nTall\nBall" | awk '/[CT]all/'

输出 (Output)

执行此代码时,您将获得以下结果 -

Call
Tall

独家套装

在专用集中,克拉否定了方括号中的字符集。 例如,以下示例仅打印Ball

例子 (Example)

[jerry]$ echo -e "Call\nTall\nBall" | awk '/[^CT]all/'

执行此代码时,您将获得以下结果 -

输出 (Output)

Ball

改变(Alteration)

垂直条允许正则表达式进行逻辑OR运算。 例如,以下示例打印BallCall

例子 (Example)

[jerry]$ echo -e "Call\nTall\nBall\nSmall\nShall" | awk '/Call|Ball/'

执行此代码时,您将获得以下结果 -

输出 (Output)

Call
Ball

零或一次出现

它匹配前一个字符的零次或一次出现。 例如,以下示例匹配ColourColor 。 我们使用?作为一个可选字符?

例子 (Example)

[jerry]$ echo -e "Colour\nColor" | awk '/Colou?r/'

执行此代码时,您将获得以下结果 -

输出 (Output)

Colour
Color

零次或多次出现

它匹配前一个字符的零次或多次出现。 例如,以下示例匹配ca, cat, catt,等。

例子 (Example)

[jerry]$ echo -e "ca\ncat\ncatt" | awk '/cat*/'

执行此代码时,您将获得以下结果 -

输出 (Output)

ca
cat
catt

一次或多次发生

它匹配前一个字符的一个或多个匹配项。 例如,下面的示例匹配2的一个或多个匹配项。

例子 (Example)

[jerry]$ echo -e "111\n22\n123\n234\n456\n222"  | awk '/2+/'

执行上面的代码时,您会得到以下结果 -

输出 (Output)

22
123
234
222

Grouping

Parentheses ()用于分组和字符| 用于替代品。 例如,以下正则表达式匹配包含Apple Juice or Apple Cake

例子 (Example)

[jerry]$ echo -e "Apple Juice\nApple Pie\nApple Tart\nApple Cake" | awk 
   '/Apple (Juice|Cake)/'

执行此代码时,您将获得以下结果 -

输出 (Output)

Apple Juice
Apple Cake