【shell中的awk练习】

1、获取根分区剩余大小
[root@node1 ~]# df -h | awk ‘//$/ {print $4}’
15G

在这里插入图片描述
2、获取当前机器ip地址
[root@node1 ~]# ifconfig ens33 | awk ‘/inet / {print $2}’
192.168.131.108

在这里插入图片描述
3、统计出apache的access.log中访问量最多的5个IP
[root@node1 ~]# awk ‘{addr[$1]++} END{for (a in addr) {print addr[a],a}}’ access.log| sort -nr | head -5

4、打印/etc/passwd中UID大于500的用户名和uid
[root@node1 ~]# awk -F: ‘$3>500 {print $1,$3}’ /etc/passwd

【shell中的awk练习】_第1张图片
5、/etc/passwd 中匹配包含root或net或ucp的任意行
[root@node1 ~]# awk ‘$0"root"||$0"net"||$0~“ucp”’ /etc/passwd

在这里插入图片描述
6、处理以下文件内容,将域名取出并根据域名进行计数排序处理(百度搜狐面试题)
test.txt
http://www.baidu.com/index.html
http://www.baidu.com/1.html
http://post.baidu.com/index.html
http://mp3.baidu.com/index.html
http://www.baidu.com/3.html
http://post.baidu.com/2.html
[root@node1 ~]# awk -F"/" ‘{na[$3]++} END{for (n in na) {print na[n],n}}’ test.txt | sort -nr

在这里插入图片描述
7、请打印出/etc/passwd 第一个域,并且在第一个域所有的内容前面加上“用户帐号:”
[root@node1 ~]# awk -F: ‘{print “用户账号:”$1}’ /etc/passwd

在这里插入图片描述
8、请打印出/etc/passwd 第三个域和第四个域
[root@node1 ~]# awk -F: ‘{print $3,$4}’ /etc/passwd

在这里插入图片描述
9、请打印第一域,并且打印头部信息为:这个是系统用户,打印尾部信息为:"=="
[root@node1 ~]# awk -F: 'BEGIN {print “这个是系统用户”} {print $1} END {print "
="}’ /etc/passwd

【shell中的awk练习】_第2张图片
10、请打印出第一域匹配daemon的信息.
[root@node1 ~]# awk -F: ‘$1==“daemon” {print}’ /etc/passwd

在这里插入图片描述
11、请将/etc/passwd 中的root替换成gongda,记住是临时替换输出屏幕看到效果即可.
[root@node1 ~]# sed -n ‘s/root/gongda/g p’ /etc/passwd

在这里插入图片描述
12、请匹配passwd最后一段域bash结尾的信息,有多少条
[root@node1 ~]# awk -F: '{arr[KaTeX parse error: Expected 'EOF', got '}' at position 6: NF]++}̲ END{for (v in …"

在这里插入图片描述
13、请同时匹配passwd文件中,带mail或bash的关键字的信息
[root@node1 ~]# awk ‘$0"mail"||$0"bash"’ /etc/passwd

【shell中的awk练习】_第3张图片

你可能感兴趣的:(shell)