awk(是一种处理文本文件的应用程序,它依次处理文件的每一行,并读取里面的每一个字段。)
awk 包含几个特殊的内建变量(可直接用)如下所示:
1、获取根分区剩余大小
#可以使用df -h命令来查看所有已挂载的文件系统的磁盘空间使用情况
[root@node1 ~]# df -h | awk '/\/$/ {print $4}'
#在AWK中,NF是一个内置变量,代表当前记录的字段数
[root@node1 ~]# df -h | awk '$NF=="/" {print $4}'
2、获取当前机器ip地址
[root@node1 ~]# ifconfig ens160 | awk '/inet /'
[root@node1 ~]# ifconfig ens160 | awk '/inet / {print $2}'
3、统计出apache的access.log中访问量最多的5个IP
#在Linux中,uniq -c命令用于计算和报告重复行的数量。-c选项告诉uniq命令在输出中包含每行的重复次数。
[root@node1 ~]# awk '{print $1'} /var/log/httpd/access_log | sort |uniq -c
4、打印/etc/passwd中UID大于500的用户名和uid
#在AWK中,-F选项用于指定输入字段的分隔符。默认情况下,AWK使用空格或制表符作为字段分隔符。但是,你可以使用-F选项来更
改这个分隔符。
[root@node1 ~]# awk -F: '$3>500 {print $1, $3}' /etc/passwd
5、/etc/passwd 中匹配包含root或net或ucp的任意行
[root@node1 ~]# awk '/root|net|ucp/' /etc/passwd
6、处理以下文件内容,将域名取出并根据域名进行计数排序处理(百度搜狐面试题)
[root@node1 ~]# cat test.txt
[root@node1 ~]# awk -F/ '{print $3}' test.txt | sort |uniq -c
7、请打印出/etc/passwd 第一个域,并且在第一个域所有的内容前面加上“用户帐号:”
[root@node1 ~]# awk -F: 'BEGIN{print "用户账号:"}{print $1}' /etc/passwd
8、请打印第一列,并且打印头部信息为:这个是系统用户,打印尾部信息为:"================"
[root@node1 ~]# awk -F: 'BEGIN{print "这个是系统用户"}{print $1}END{print "================"}' /etc/passwd
9、请打印出第一列匹配daemon的信息.
[root@node1 ~]# awk -F: '/^daemon/ {print $0}' /etc/passwd
[root@node1 ~]# awk -F: '$1~/daemon/ {print $0}' /etc/passwd
10、请将/etc/passwd 中的root替换成gongda,记住是临时替换输出屏幕看到效果即可.
[root@node1 ~]# sed -n 's/root/gongda/g p' /etc/passwd
11、请匹配passwd最后一段域bash结尾的信息,有多少条
#在Linux中,wc -l命令用于计算文件中的行数。-l选项告诉wc命令我们想要计算的是行数。
[root@node1 ~]# awk '/bash$/' /etc/passwd | wc -l
12、请同时匹配passwd文件中,带mail或bash的关键字的信息
[root@node1 ~]# awk '/mail|bash/' /etc/passwd