經典shell面試題整理

來源:互聯網
上載者:User
一、取出/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命令統計行數。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.