awk 使用正则表达式

版权声明:如若转载,请联系作者。 https://blog.csdn.net/liu16659/article/details/85168474

awk 使用正则表达式

1. 正则表达式

2. awk命令

3. 在awk中使用正则表达式

3.1 实战案例1
[root@server4 temp]# echo "Abaidu.comB" | awk '/^A.*?B/'{print}
Abaidu.comB

这里解释一下这个正则表达式。
^A.*?B 指的是:以A 字符开头; .* 指的是任意字符可以出现任意次;? 表示之前的字符串必须匹配一到多次;B表示必须包含这个字符 B

3.2 实战案例2
[root@server4 temp]# echo "sdfAbaidu.comB" | awk '/^s.*?B$/'{print}
sdfAbaidu.comB

这里新添的知识点有:B$是以字符B结尾的字符串。

3.3 实战案例3
[root@server4 temp]# awk '/in?/' data1.txt 
2 winxp 4000
4 linux 1000
[root@server4 temp]# cat data1.txt 
1 mac 2000
2 winxp 4000
3 bsd 1000
4 linux 1000

这里的in?表示的是包含in字符串的行。

3.4 实战案例4
[root@server4 temp]# awk '/m(a)*(ab)?c/' data1.txt 
1 mac 2000
5 maaaabc 200
[root@server4 temp]# cat data1.txt 
1 mac 2000
2 winxp 4000
3 bsd 1000
4 linux 1000
5 maaaabc 200

这里的正则表达式含义是:(a)*指的是可以匹配0或多次a(ab)? 指的是(ab) 必须匹配0或1次。

3.5 实战案例5
[root@server4 temp]# awk '/a{1}/' data1.txt 
1 mac 2000
5 maaaabc 200

a{1}指的就是字符a必须匹配1次。

如果说要是想在匹配成功之后,执行别的操作,如下:

[root@server4 temp]# awk '/a.c/''{print "ok"}' data1.txt 
ok

这里的操作就是,如果有匹配a.c,那么输出ok,否则什么也不做。上述的命令可以简化成如下的样子:

[root@server4 temp]# awk '/a.c/{print "ok"}' data1.txt 
ok

如果能够匹配数字,则输出ok。

[root@server4 temp]# awk '/[0-9]/{print "ok"}' data1.txt 
ok
ok
ok
ok
ok

可以看到这里匹配了很多的ok。 是因为每匹配成功一次,就会输出一个ok

猜你喜欢

转载自blog.csdn.net/liu16659/article/details/85168474