awk简单用法

准备一份文档:adb shell ps > text.txt

1.截取文档中的某个字段

-F 指定分隔符,不加默认空格或tab分隔符,print打印自定义的内容需要用" "扩起来

awk -F ':'

adb shell ps|grep -v 'root'|awk {print "packageName:" $9}

指定多个分隔符 awk -F [<|>]  filename

指定汉字作为分隔符 awk -F字 filename;awk -F '(路|非)' filename

 

 

2.匹配字符或字符串 字符串用//分隔

awk '/root/' text.txt 打印包含root的行

awk '$1~/root/' text.txt 打印包含非root的行

 awk '/root/ {print $1} /system/ {print $1}' text.txt 打印包含root和system的行的第3列

判断上个命令执行成功,awk '/root/ {print $1} /system/ {print $1}' text.txt|grep -Ev 'root|system'

awk '$1~/root/ {print $1}' text.txt 

3.条件操作符

== !=  > < >= <=  && ||

awk可以用逻辑运算符号判断,但是awk会将所有内容视为字符,而非数字,因此此处的< > <= <=不是指数学关系

awk '$1=="100"' text.txt  精确匹配

awk '$1>="100"' text.txt 

!= 即为不匹配

awk '$2!="100" {print $2}' text.txt|grep 100 发现没有100的进程

awk  '$2=="100" || $2=="44"' text.txt 

awk '$2<="44" && $2 >='100'' ' text.txt

4.awk内置变量

NF:用分隔符分隔后一共有多少段,$NF会打印最后一个字段

NR:行数

RS:行记录分隔符

FS:记录分隔符

BEGIN END

awk '{print NF, $NF}' text.txt|head -n 5

awk '{print NR}' text.txt 只打印行数,不打印内容

awk 'NR<5 ' text.txt   打印前4行

5.awk中的数学运算

 将某个字段改成指定的字符串

awk '{$7=$3+$4;print{$3,$4,$7}}' text.txt

计算某个段的总和

awk '{(tot+=$3)};END {print tot}' text.txt

在awk中可以使用if判断,for循环

awk '{if ($1=="root") print $0}' text.txt 

 

posted on 2018-06-10 07:21  singleSpace  阅读(334)  评论(0编辑  收藏  举报