版权声明:如若转载,请联系作者。 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