awk介绍
报告生成器,格式化文本输出
处理机制类似sed命令,自带循环处理 读入一行处理一行然后自动读取下一行再进行处理
sed命令换行的标识是固定的,只能是回车换行. awk里面的换行符是可以自定义的.
awk自动把读入的行按照指定的切割符号切割成若干个字段 默认的切割符号是空白符号(包括连续的空白符号,tab键,回车换行符)
基础语法
awk [options] 'program' var=value file
awk [options] -f programfile var=value file
awk [options] 'BEGIN{action;..} pattern{ action;....} END {action;....}' file
通常由: BEGIN语句块 能够使用模式匹配的通用语句块 END语句块 三部分组成
第一步: 先执行 BGEIN 语句块 经常用于打印表头
第二步: 从文件或者标准输入读取一行,然后执行pattern语句 它会逐行扫描文件,直到文件全部读取完毕
第三步: 处理完文件或者输入流的最后一行后,最后执行的语句块 经常用于进行数据汇总
pattern语句如果没有提供 默认执行 {print } 就是打印每一个读取到的行
选项 options
-F 指明输入时用到的字段分隔符号
-v var=value 自定义变量
awk内置变量
FS 表示把行按照这个变量进行切割成列
OFS 表示按这个字符把列进行拼装组合输出
RS 表示按照这个变量作为行的分隔符
ORS 表示以这个符号连接每行输出的结果
NF 表示字段的数量大小
NR 表示行号
FNR 多个文件的时候各自的文件行号
FILENAME 表示当前的文件名称
FS:输入字段分隔符,默认为空白字符
awk -v FS=':' '{print $1,FS,$3}’ /etc/passwd
awk –F: '{print $1,$3,$7}’ /etc/passwd
OFS:输出字段分隔符,默认为空白字符
awk -v FS=‘:’ -v OFS=‘:’ '{print $1,$3,$7}’ /etc/passwd
RS:输入记录分隔符,指定输入时的换行符 默认是换行符
awk -v RS=' ' ‘{print }’ /etc/passwd
ORS:输出记录分隔符,输出时用指定符号代替换行符 默认是换行符
awk -v RS=' ' -v ORS='###'‘{print }’ /etc/passwd
NF:字段数量
awk -F: ‘{print NF}’ /etc/fstab
awk -F: '{print NF,"----"$NF"----"$(NF-1)}' /etc/passwd
引用内置变量不用$
awk -F: '{print $(NF-1)}' /etc/passwd
NR:记录号
awk '{print NR}' /etc/fstab ; awk END'{print NR}' /etc/fstab
FNR:各文件分别计数自己的记录号
awk '{print FNR}' /etc/fstab /etc/inittab
FILENAME:当前文件名
awk '{print FILENAME}’ /etc/fstab
ARGC:命令行参数的个数
awk '{print ARGC}’ /etc/fstab /etc/inittab
awk ‘BEGIN {print ARGC}’ /etc/fstab /etc/inittab
ARGV:数组,保存的是命令行所给定的各参数
awk ‘BEGIN {print ARGV[0]}’ /etc/fstab /etc/inittab ARGV[0]代表的awk自己本身 ARGV[1] 代表/etc/fstab ARGV[2]代表/etc/inittab
awk ‘BEGIN {print ARGV[1]}’ /etc/fstab /etc/inittab
awk自定义变量
自定义变量(区分字符大小写)
(1) -v var=value
(2) 在program中直接定义
(3) 变量最好先定义赋值然后再去使用
printf格式化输出
1.输出信息默认不会换行,需要显示指定换行控制符 \n
格式符:
1. %c 显示字符的ASCII码
2. %d,%i 显示十进制数字
3. %s 显示字符串
4. %% 显示%自身
5. %f 显示浮点数
awk -F: '{printf "%s:%s\n",$1,$3}' /etc/passwd
awk -F: 'BEGIN{print "username uid"}{printf"%s %s\n", $1,$3}' /etc/passwd
awk实例
从文件中读取program
cat awkscript
{print script,$,$}
[root@centos7 ~]# awk -F: -f awkscript script="awkkk" /etc/passwd
awkkk root x
awkkk bin x
awkkk daemon x
[root@centos7 ~]# awk -F: '{printf"Username: %s\n",$1}' /etc/passwd
Username: root
Username: bin
Username: daemon
输出json字典
[root@centos7 ~]# awk -F: '{printf "Username:%s,UID:%d\n",$1,$3}' /etc/passwd
Username:root,UID:
Username:bin,UID:
[root@centos7 ~]# awk -F: '$0 ~ /root/{print $1}' /etc/passwd
root
operator
rooter
[root@centos7 ~]# awk -F: '$0 ~ /^root/{print $1}' /etc/passwd
root
rooter
awk '$0 !~ /root/' /etc/passwd
bin:x:::bin:/bin:/sbin/nologin
daemon:x:::daemon:/sbin:/sbin/nologin
[root@centos7 ~]# awk -F: '$3==0' /etc/passwd
root:x:::root:/root:/bin/bash
[root@centos7 ~]# awk '{print 2^10}'
e [root@centos7 ~]# awk -F: '{print $1":"$3}' /etc/passwd
root:
bin:
daemon:
[root@centos7 ~]# df | awk '{print $1,$3}'
Filesystem Used
/dev/sda2
devtmpfs
tmpfs
[root@centos7 ~]# awk -v FS=: '{print $1,$3}' /etc/passwd
root
[root@centos7 ~]# awk -v FS=: '{print $1FS$3}' /etc/passwd
root:
shell变量传递给awk
[root@centos7 ~]# fs=":";awk -v FS=$fs '{print $1FS$3}' /etc/passwd
root:
bin: [root@centos7 ~]# awk -v ORS="****" '{print $1}' a2
********o********o********You have new mail in /var/spool/mail/root
[root@centos7 ~]# awk '{print $1}' a2 o o
[root@centos7 ~]# df | grep '^/dev/sd'|awk '{print $1,$5}'
/dev/sda2 %
/dev/sda3 %
/dev/sda1 %
[root@centos7 ~]# df | grep '^/dev/sd'|awk -v FS=% '{print $1}'
/dev/sda2
/dev/sda3
/dev/sda1
[root@centos7 ~]# df | grep '^/dev/sd'|awk -v FS=% '{print $1}'|awk '{print $1,$5}'
/dev/sda2
/dev/sda3
/dev/sda1
[root@centos7 ~]# awk -F: '{print NF,$NF,$(NF-1)}' /etc/passwd
/bin/bash /root
/sbin/nologin /bin
/sbin/nologin /sbin
/sbin/nologin /var/adm
/sbin/nologin /var/spool/lpd