第七次作业部分

您所在的位置:网站首页 awk只取第一行 第七次作业部分

第七次作业部分

2023-01-09 18:45| 来源: 网络整理| 查看: 265

文章目录 1、获取根分区剩余大小2、获取当前机器ip地址3、统计出apache的access.log中访问量最多的5个IP4、打印/etc/passwd中UID大于500的用户名和uid5、/etc/passwd 中匹配包含root或net或ucp的任意行6、处理以下文件内容,将域名取出并根据域名进行计数排序处理(百度搜狐面试题)7、请打印出/etc/passwd 第一个域,并且在第一个域所有的内容前面加上“用户帐号:”8、请打印出/etc/passwd 第三个域和第四个域9、请打印第一域,并且打印头部信息为:这个是系统用户,打印尾部信息为:"================"10、请打印出第一域匹配daemon的信息.11、请将/etc/passwd 中的root替换成gongda,记住是临时替换输出屏幕看到效果即可.12、请匹配passwd最后一段域bash结尾的信息,有多少条13、请同时匹配passwd文件中,带mail或bash的关键字的信息

1、获取根分区剩余大小 df -hl | awk '/\/$/ {print $4}'

在这里插入图片描述

2、获取当前机器ip地址 ifconfig | awk '/\/ {print $2}'| head -1

在这里插入图片描述

3、统计出apache的access.log中访问量最多的5个IP 没得这个文件啊 ```linux cat access.log|awk '{print $1}'|sort -n|uniq -c|sort -nr|head -5 ``` 4、打印/etc/passwd中UID大于500的用户名和uid awk -F : '$3>500 {print "用户名:"$1"\t\tUID: "$3}' /etc/passwd

在这里插入图片描述

5、/etc/passwd 中匹配包含root或net或ucp的任意行 awk -n '/root|net|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

awk -F / '{print $3}' test.txt| sort -r| uniq -c

在这里插入图片描述

7、请打印出/etc/passwd 第一个域,并且在第一个域所有的内容前面加上“用户帐号:” awk -F : '{print "用户账号:"$1}' /etc/passwd

在这里插入图片描述

8、请打印出/etc/passwd 第三个域和第四个域 awk -F : '{print "UID:"$3" GID:"$4}' /etc/passwd

在这里插入图片描述

9、请打印第一域,并且打印头部信息为:这个是系统用户,打印尾部信息为:“================” awk -F : 'BEGIN{print "这是系统用户"}{print $1}END{print "====="}' /etc/passwd 10、请打印出第一域匹配daemon的信息. awk -F : '/^daemon/ {print $1}' /etc/passwd

在这里插入图片描述

11、请将/etc/passwd 中的root替换成gongda,记住是临时替换输出屏幕看到效果即可. sub匹配第一次出现的符合模式的字符串,相当于 sed 's//' 。

gsub匹配所有的符合模式的字符串,相当于 sed ‘s//g’ 。 例如:

awk '{sub(/Mac/,"Macintosh");print}' urfile 用Macintosh替换Mac awk '{sub(/Mac/,"MacIntosh",$1); print}' file 第一个域内用Macintosh替换Mac

把上面sub换成gsub就表示在满足条件得域里面替换所有的字符。 麻了,我居然在实验正则

awk -F : 'gsub(/root/,"gongda")' /etc/passwd

在这里插入图片描述

12、请匹配passwd最后一段域bash结尾的信息,有多少条

想着这都是awk的练习就用AWK来做了

awk -F : '{print $7}' /etc/passwd | awk -F / '{if($3=="bash"){x++}} END{print x}'

在这里插入图片描述

13、请同时匹配passwd文件中,带mail或bash的关键字的信息 awk '$0~/mail|bash/' /etc/passwd

在这里插入图片描述



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3