正则表达式之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)求和

未分类