一、取出/etc/passwd檔案中shell出現的次數
問題:下面是一個/etc/passwd檔案的部分內容。題目要求取出shell並統計次數,shell是指後面的/bin/bash,/sbin/nologin等,如下面/bin/bash出現12次,/sbin/nologin出現3次。
hyn:x:525:500::/home/hyn:/bin/bashljlxx:x:526:500::/home/ljlxx:/bin/bashlzj:x:527:500::/home/lzj:/bin/bashwfly:x:528:500::/home/wfly:/bin/bashsquid:x:23:23::/var/spool/squid:/sbin/nologinwyj:x:529:500::/home/wyj:/bin/bashqemu:x:107:107:qemu user:/:/sbin/nologinradvd:x:75:75:radvd user:/:/sbin/nologindungbee:x:530:500::/home/dungbee:/bin/bashmysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/bashscidb:x:531:531::/home/scidb:/bin/bashpostgres:x:532:532::/home/postgres:/bin/bashcrane:x:533:533::/home/crane:/bin/bashtest:x:534:534::/home/test:/bin/bashhguser: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,250100 jason smith $5,000200 john doe $500300 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 Jason Smith :100 $5,000 等。預設合并符號為tab符號,更多paste命令請參照http://snailwarrior.blog.51cto.com/680306/144462/。awk用於提取除了tab符號的其餘4列。tr命令用於將字串中所有大寫字元轉換為小寫字元。更多選項參見http://www.huanxiangwu.com/238/linux-tr%E5%91%BD%E4%BB%A4%E8%AF%A6%E8%A7%A3。sort命令對字元排序。sort -k 2表示按檔案第2個域排序,這裡第二個域為姓名,所以是按姓名升序排序。如果要降序排列,則要用sort -k 2r。更多sort命令參見http://www.360doc.com/content/10/0925/15/1107705_56263541.shtml。三、列印本機交換分區大小問題:列印本機交換分區大小,輸出如下
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命令終止。五、百度指令碼面試題1)寫指令碼實現,可以用shell、perl等。在目錄/tmp下找到100個以abc開頭的檔案,然後把這些檔案的第一行儲存到檔案new中。參考答案1:
#!/bin/shfor filename in `find /tmp -type f -name "abc*"|head -n 100`dosed -n '1p' $filename>>newdone
解析:第一,用到了find命令,其中-type
f表示選取普通檔案,-name用於設定檔案名稱;第二,head -n 100命令用於取出前100項。第三,sed -n ’1p’用於取出檔案的第一行內容。第四,>>new表示追加到檔案new中。
參考答案2:
find /tmp -type f -name “abc*” | head -n 100 | xargs head -q -n 1 >> new
2)寫指令碼實現,可以用shell、perl等。把檔案b中有的,但是檔案a中沒有的所有行,儲存為檔案c,並統計c的行數。
參考答案:
grep -vxFf a b | tee c | wc -l
解析:grep選取-v表示不選擇匹配的行,-F表示匹配的模式按行分割,-f a表示匹配模式來自檔案a,最後表示目標檔案b。即grep命令從b中選取a中不存在的行。 tee c命令建立檔案c,wc -l命令統計行數。