awk:编程语言/数据处理引擎
- 基于模式匹配检查输入文本,逐行处理并输出
- 通常用在shell脚本中,获取指定的数据
- 单独使用时,可对文本数据做统计
主要用法
- 格式1:前置命令 | awk [选项] '[条件]{指令}'
- 格式2 : awk [选项] '[条件]{指令}' 文件..
[root@localhost ~]# df -h |awk '{print $2}' #打印第二列
容量
50G
482M
497M
497M
497M
38G
497M
100M
选项 -F 可指定分隔符
[root@localhost ~]# awk -F: '{print $1,$7}' /etc/passwd #指定以:为分隔符
root /bin/bash
bin /sbin/nologin
daemon /sbin/nologin
adm /sbin/nologin
[root@localhost ~]# awk -F[:/] '{print $1,$7}' /etc/passwd #以:或者/为分隔符
root root
bin bin
daemon sbin
adm var
[root@localhost ~]# awk -F[:/] '{print NR,NF}' /etc/passwd #打印行号和列数
1 10
2 10
3 10
4 11
5 12
[root@localhost ~]# awk -F: '{print $1,"的解释器:",$7}' /etc/passwd #中间可以添加常量
root 的解释器: /bin/bash
bin 的解释器: /sbin/nologin
daemon 的解释器: /sbin/nologin
[root@localhost cgi-bin]# awk '/Failed/{print $11}' /var/log/secure #按照条件Failed 打印11列
awk [选项] 'BEGIN{指令} {指令} END{指令}' 文件
- BEGIN{ } 行前处理,读取文件内容前执行,指令执行1次
- { } 逐行处理,读取文件过程中执行,指令执行n次
- END{ } 行后处理,读取文件结束后执行,指令执行1次
[root@localhost cgi-bin]# awk 'BEGIN{print 3*2}'
6
[root@localhost cgi-bin]# awk -F: 'BEGIN{print "用户名 家目录 UID"} {print $1,$6,$3} END{print "总用户:"NR}' /etc/passwd
用户名 家目录 UID
root /root 0
bin /bin 1
[root@localhost ~]# awk -F: '$1~/root/' /etc/passwd #第一列包含root的行
root:x:0:0:root:/root:/bin/bash
[root@localhost ~]# awk -F: '$1!~/root/' /etc/passwd #第一列不包含root的行
[root@localhost ~]# awk -F: 'NR==4' /etc/passwd #打印第4行
adm:x:3:4:adm:/var/adm:/sbin/nologin
[root@localhost ~]# awk -F: '$3>=1000' /etc/passwd #打印第三列数字大于等于1000的行
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
lisi:x:1000:1000:lisi:/home/lisi:/bin/bash