正则表达式之awk
- awk兼具sed所有的功能,并且更加强大。它也是流式编辑器,针对文档中的行来操作。一行一行的执行。
(1)截取文档中的某个字段
head -n2 test.txt |awk -F ': ' '{print $1}' //-F用来指定分隔符。不加-F选项,默认使用空格或者tab为分隔符,print为打印的意思。 $1表示打印第1字段 $0表示整行
如果需要截取多个字段,可以在{ }中用“,”来分隔
(2)指定分隔符号
awk -F ':' '{print $1"#"$5"#"$6}' test.txt //将之前的:分隔符号替换为#,必须使用双引号引起来。
(3)匹配功能
awk '/oo/' test.txt //匹配出现oo的行
(4)匹配某段中出现的字符
awk -F ':' '$1 ~ /oo/' test.txt
awk命令可以直接使用特殊符号而不用使用转义字符
(5)支持多个条件匹配
awk -F ':' '/oo/ {print $1,$4} /user1/ {print $1,$6}' test.txt
(6)条件操作符
awk -F ':' '$3==0' test.txt //这里表示打印第3段等于0的行,要想等于必须使用2个=,不然就是赋值了。
也可以这样来打印
awk -F ':' '$3>=500 {print $0}' test.txt
这里写图片描述在和数字进行比较时,若把比较的数字用双引号括起来,那么awk不会认为是数字,而会认为是字符,那么就会按ASCII码表来排序,得不到想要的结果
(7)打印出某段不等于xx的行
awk -F ':' '$7!="/sbin/nologin" {print $0} ' test.txt //字符作为判断条件则是要使用双引号括起来的 !=表示不等于
(8)2字段之间比较
awk -F ':' '$3<$4' test.txt //打印第3段小于第4段的行,比较的是数字
awk -F ':' '$3==$4' test.txt //打印第3段与第4段相同的行。
(9)在2个字符之间查找
awk -F ':' '$3>"4" && $3<"8"' test.txt //第3段大于某个字符并且小于某个字符 。这里数字使用了双引号,所以表示字符
2个条件满足一个的也打印出来
- awk的内置变量
(1)OFS和-F选项有类似的功能,也是用来定义分隔符的,但是它是在输出的时候定义的
(2)变量NR的用法 表示行号
(3变量NF表示用分隔符分隔后一共有多少段
(4)使用NR打印前多少行
(5)打印2个条件同时满足的行
(6)2个变量的应用
(7)赋值
赋值后没有了分隔符号了,使用OFS重新定义
(8)求和
原文出处:csdn -> http://blog.csdn.net/chunyang315/article/details/79091460