什么是awk
重要的文本处理工具,也是一个重要的报告生成器,利用awk可以处理复杂的文本,摘取出需要的数据,并且对数据进行处理计算之后从而生成我们想要的数据报告,因此称之为报告生成器。
awk工作模式介绍
awk的内置变量
# $0表示打印整行,因此$0就打印了所有行
awk '{print $0}' /etc/passwd
# 在BEGIN指定了File Separator,然后打印了第一列
awk 'BEGIN{FS=":"}{print $1}' /etc/passwd
# 假如不指定分隔符,默认以空格或者TAB键为分隔符,所以在不指定分隔符的情况下会使用默认分隔符
# NF:Number of fields,输出用分隔符分割之后的字段个数
awk '{print NF}' /etc/passwd
# NR: number of row,假如对多个文件,不会对每个文件单独计数
awk '{print NR}' /etc/passwd
# FNR:file number row,会对每个文件单独计行数
# FS:字段分隔符
awk 'BEGIN{FS="|"{print $2}}' list
# RS:行分隔符,ROW separator,多个内置命令之间用分号分割
awk 'BEGIN{RS="--";FS="|"}{print $3}' /etc/passwd
# OFS:输出字段分隔符,output field separator
# ORS:输出行分隔符
awk 'BEGIN{OFS="|";ORS="FUCK"}{print $1,$3,$4}' /etc/passwd
# NF的妙用,输出每一行最后一个字段
awk '{print $NF}' /etc/passwd
awk格式化输出之printf
#printf不加换行符
awk '{printf $1,$3,$4}' /etc/passwd
#采用%s占位,然后,来进行格式化输出
awk 'BEGIN{FS=":"}{printf "%sZz~~\n",$1}' /etc/passwd
# 采用%ns来指定宽度,默认右对齐的方式
awk 'BEGIN{FS=":"}{printf "%20s--->%10s\n",$1,$4}' /etc/passwd
# 设置左对齐
awk 'BEGIN{FS=":"}{printf "%-20s--->%-10s\n",$1,$4}' /etc/passwd
awk的模式匹配
动作表达式
# 匹配空行,然后打印
awk '/^$/{row++}END{print row}' /etc/passwd
awk动作中的条件及循环语句
awk 'BEGIN{FS=":"}{if($3<50 && $3>1) print $0}' /etc/passwd
循环语句
求平均分示例
看到7-9