问题:下面是一个/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
解析:
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
解析:
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 Jason Smith :100 $5,000 等。默认合并符号为tab符号,更多paste命令请参照 http://snailwarrior.blog.51cto.com/680306/144462/。
Swap:1024M
参考答案:
top -n 1|grep Swap|sed 's/k.*//'|awk '{print $1,$2/1000"M"}'
解析:
Swap: 16779884k total, 0k used, 16779884k free, 3268200k cached
Swap: 16779884
awk命令输出内容,对第二个参数除以1000.
问题:清除本机除了当前登陆用户以外的所有用户。
参考答案:
kill $(who -u|grep -v `whoami`|awk '{print $6}'|sort -u)
解析:
#!/bin/sh
for filename in `find /tmp -type f -name "abc*"|head -n 100`
do
sed -n '1p' $filename>>new
done
find /tmp -type f -name “abc*” | head -n 100 | xargs head -q -n 1 >> new
grep -vxFf a b | tee c | wc -l
解析:grep选取-v表示不选择匹配的行,-F表示匹配的模式按行分割,-f a表示匹配模式来自文件a,最后表示目标文件b。即grep命令从b中选取a中不存在的行。