您的位置:首页 > 其它

正则表达式之awk

2018-01-18 01:03 176 查看
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个条件同时满足的行



(3)2个变量的应用



(4)赋值



赋值后没有了分隔符号了,使用OFS重新定义

(4)求和

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: