awk报告生成器

2.awk的处理机制

awk处理机制:根据模式一次从文件中抽取一行文本,对这行文本进行切片(默认使用空白字符作为分隔符)

[root@server mnt]# cat test
this  | is | a | file
 $1     $2  $3    $4

awk '{print $0}' test	##$0表示输出一整行
this is a file
awk '{print $1}' test
this
awk '{print $4}' test
file
awk '{print $1,$2}' test	##显示两个字段
this is

以:为分隔符,打印文件/etc/passwd的第一列和第三列

awk -F ":" '{print $1,$3}'  /etc/passwd

在这里插入图片描述

3.awk常用变量

awk ‘{print FILENAME,NR}’ /etc/passwd ##输出文件名,和当前操作的行号
awk -F: ‘{print NR,NF}’ /etc/passwd ##输出每次处理的行号,以及当前以":"为分隔符的字段个数

总结:awk ‘{print “第NR行”,“有NF列”}’ /etc/passwd

BEGIN{}:读入第一行文本之前执行的语句,一般用来初始化操作
{}:逐行处理
END{}:处理完最后以行文本后执行,一般用来处理输出结果

awk ‘BEGIN { a=34;print a+10 }’

awk -F: ‘BEGIN{print “REDHAT”} {print NR;print } END {print “WESTOS”}’ passwd ##文件开头加REDHAT,末尾加WESTOS,打印行号和内容

awk -F: ‘/bash$/{print}’ /etc/passwd ##输出以bash结尾的

awk -F: ‘NR==3 {print}’ /etc/passwd

awk -F: ‘NR % 2 == 0 {print}’ /etc/passwd ##偶数行

awk -F: ‘NR >=3 && NR <=5 {print }’ /etc/passwd

扫描二维码关注公众号,回复: 4958464 查看本文章

awk ‘BEGIN{i=0}{i+=NF}END{print i}’ linux.txt ##统计文本总字段个数

#if单分支语句
awk -F: ‘BEGIN{i=0}{if( 7   / b a s h 7~/bash /){i++}}END{print i}’ /etc/passwd ##统计登录shell为bash的用户

#if双分支
awk -F: ‘BEGIN{i=0;j=0}{if($3<=500){i++}else{j++}}END{print i,j}’ /etc/passwd ##统计uid小于等于500和大于500的用户个数

#for循环
awk ‘BEGIN{for(i=1;i<=5;i++){print i}}’

猜你喜欢

转载自blog.csdn.net/qq_43287266/article/details/85264800