awk具备完整的编程特性,同时也是一种语言解析引擎。
RS 行记录分隔符 row行
FS 记录分隔符 field列
NR记录符: row行数
NF字段数:field列数
BEGIN END
BEGIN:预处理
END:已经对输入做处理了,处理完成后,再做后面的事情
echo $PATH|awk 'BEGIN{RS=":"}{print $0}'
echo $PATH|awk 'BEGIN{RS=":"}{print NR,$0}'
echo $PATH|awk 'BEGIN{RS=":"}{print NR}'
对以下内容的第一列求和

1     2    3
4    5    6
7    8    9

awk '{sum+=$1}END{print sum}' sum.txt
echo $PATH|awk !BEGIN{RS=":"}{print$0}'|awk -F "/" '{print $1,$2,$3,$4}'
拿到第2列的最小值
awk 'NR==1{min=$2;next}{min=min<$2}END{print min}' sum.txt

准备一份文档: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

12-24 05:08