您的位置:首页 > 运维架构 > Shell

统计文本中某值字段数量-cat-awk-sort-uniq-c

2016-04-09 22:38 519 查看


一、取出/etc/passwd文件中shell出现的次数

问题:下面是一个/etc/passwd文件的部分内容。题目要求取出shell并统计次数,shell是指后面的/bin/bash,/sbin/nologin等,如下面/bin/bash出现12次,/sbin/nologin出现3次。

hyn:x:525:500::/home/hyn:/bin/bash  
ljlxx:x:526:500::/home/ljlxx:/bin/bash  
lzj:x:527:500::/home/lzj:/bin/bash  
wfly:x:528:500::/home/wfly:/bin/bash  
squid:x:23:23::/var/spool/squid:/sbin/nologin  
wyj:x:529:500::/home/wyj:/bin/bash  
qemu:x:107:107:qemu user:/:/sbin/nologin  
radvd:x:75:75:radvd user:/:/sbin/nologin  
dungbee:x:530:500::/home/dungbee:/bin/bash  
mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/bash  
scidb:x:531:531::/home/scidb:/bin/bash  
postgres:x:532:532::/home/postgres:/bin/bash  
crane:x:533:533::/home/crane:/bin/bash  
test:x:534:534::/home/test:/bin/bash  
hguser:x:535:535::/home/hguser:/bin/bash  

参考答案:

cat /etc/passwd|awk -F: '{print $7}'|sort|uniq -c  

解析:

使用awk根据冒号分割内容,打印输出分割后的第7列,也就是shell所在列。然后调用sort命令排序并使用uniq-c统计每个shell出现的次数。


二、文件整理

问题:

employee文件中记录了工号和姓名

employee.txt:  
100 Jason Smith   
200 John Doe   
300 Sanjay Gupta   
400 Ashok Sharma

bonus文件中记录工号和工资

bonus.txt:  
100 $5,000   
200 $500   
300 $3,000   
400 $1,250

要求把两个文件合并并输出如下
处理结果:

400 ashok sharma $1,250  
100 jason smith  $5,000  
200 john doe  $500  
300 sanjay gupta  $3,000  

参考答案:

paste employee.txt bonus.txt | awk '{print $1,$2,$3,$5}'|tr '[:upper:]' '[:lower:]'|sort -k 2  

解析:

这里用到好几个命令,包括paste,awk,tr以及sort。paste命令用于合并多个文件的同行数据,如上面两个文件employee和bonus调用paste后合并成

100 Jason Smith     100 $5,000   
200 John Doe    200 $500   
300 Sanjay Gupta    300 $3,000   
400 Ashok Sharma    400 $1,250   

paste命令可以使用-d指定合并时加入的符号。比如paste -d : employee bonus则结果变成类似100 JasonSmith :100 $5,000 等。默认合并符号为tab符号。

awk用于提取除了tab符号的其余4列。

tr命令用于将字符串中所有大写字符转换为小写字符。

sort命令对字符排序。sort -k2表示按文件第2个域排序,这里第二个域为姓名,所以是按姓名升序排序。如果要降序排列,则要用sort -k 2r。

三、打印本机交换分区大小

问题:打印本机交换分区大小,输出如下

Swap:1024M  

参考答案:

top -n 1|grep Swap|sed 's/k.*//'|awk '{print $1,$2/1000"M"}'  

解析:

top 命令显示系统资源占用情况,-n 1表示只调用1次。
grep Swap选取Swap所在行。grep命令执行后结果可能如下:

Swap: 16779884k total,        0k used, 16779884k free,  3268200k cached  

sed命令用于字符串的一些正则匹配,这里使用了替换参数,将第1个k以及后面的字符替换成了空白。这样,sed执行后,结果为:

Swap: 16779884  

awk命令输出内容,对第二个参数除以1000.

四、用户清理

问题:清除本机除了当前登陆用户以外的所有用户。
参考答案:

kill $(who -u|grep -v `whoami`|awk '{print $6}'|sort -u)  

解析:

who -u显示所有当前用户。grep -v选取当前登录用户以外的所有用户。awk打印用户进程ID。sort-u会删除相同的行。最后用kill命令终止。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  shell