經典shell面試題整理

2021-06-22 00:00:49 字數 4468 閱讀 3906

問題:下面是乙個/etc/passwd檔案的部分內容。題目要求取出shell並統計次數,shell是指後面的/bin/bash,/sbin/nologin等,如下面/bin/bash出現12次,/sbin/nologin出現3次。

[plain]view plain

copy

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  

ra***:x:75:75:ra*** 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  

[html]view plain

copy

cat /etc/passwd|awk -f: ''|sort|uniq -c  

解析:

使用awk根據冒號分割內容,列印輸出分割後的第7列,也就是shell所在列。然後呼叫sort命令排序並使用uniq -c統計每個shell出現的次數。

問題:

employee檔案中記錄了工號和姓名

[plain]view plain

copy

employee.txt:  

100 jason smith   

200 john doe   

300 sanjay gupta   

400 ashok sharma   

bonus檔案中記錄工號和工資

[plain]view plain

copy

bonus.txt:  

100 $5,000   

200 $500   

300 $3,000   

400 $1,250   

要求把兩個檔案合併並輸出如下

處理結果:

[plain]view plain

copy

400 ashok sharma $1,250  

100 jason smith  $5,000  

200 john doe  $500  

300 sanjay gupta  $3,000  

[plain]view plain

copy

paste employee.txt bonus.txt | awk ''|tr '[:upper:]' '[:lower:]'|sort -k 2  

解析:

這裡用到好幾個命令,包括paste,awk,tr以及sort。paste命令用於合併多個檔案的同行資料,如上面兩個檔案employee和bonus呼叫paste後合併成

[plain]view plain

copy

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命令請參照

awk用於提取除了tab符號的其餘4列。

tr命令用於將字串中所有大寫字元轉換為小寫字元。更多選項參見

sort命令對字元排序。sort -k 2表示按檔案第2個域排序,這裡第二個域為姓名,所以是按姓名公升序排序。如果要降序排列,則要用sort -k 2r。更多sort命令參見

問題:列印本機交換分割槽大小,輸出如下

[html]view plain

copy

swap:1024m  

[html]view plain

copy

top -n 1|grep swap|sed 's/k.*//'|awk ''  

解析:

top 命令顯示系統資源占用情況,-n 1表示只呼叫1次。

grep swap選取swap所在行。grep命令執行後結果可能如下:

[html]view plain

copy

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

sed命令用於字串的一些正則匹配,這裡使用了替換引數,將第1個k以及後面的字元替換成了空白。這樣,sed執行後,結果為:

[html]view plain

copy

swap: 16779884  

awk命令輸出內容,對第二個引數除以1000.

問題:清除本機除了當前登陸使用者以外的所有使用者。

參***:

[html]view plain

copy

kill $(who -u|grep -v `whoami`|awk ''|sort -u)  

解析:

who -u顯示所有當前使用者。grep -v選取當前登入使用者以外的所有使用者。awk列印使用者程序id。sort -u會刪除相同的行。最後用kill命令終止。

1)寫指令碼實現,可以用shell、perl等。在目錄/tmp下找到100個以abc開頭的檔案,然後把這些檔案的第一行儲存到檔案new中。

參***1:

[plain]view plain

copy

#!/bin/sh  

for filename in `find /tmp -type f -name "abc*"|head -n 100`  

do  

sed -n '1p' $filename>>new  

done  

解析:第一,用到了find命令,其中-type f表示選取普通檔案,-name用於設定檔名;第二,head -n 100命令用於取出前100項。第三,sed -n 』1p』用於取出檔案的第一行內容。第四,>>new表示追加到檔案new中。

[plain]view plain

copy

find /tmp -type f -name 「abc*」 | head -n 100 | xargs head -q -n 1 >> new  

2)寫指令碼實現,可以用shell、perl等。把檔案b中有的,但是檔案a中沒有的所有行,儲存為檔案c,並統計c的行數。 

[plain]view plain

copy

grep -vxff a b | tee c | wc -l  

解析:grep選取-v表示不選擇匹配的行,-f表示匹配的模式按行分割,-f a表示匹配模式來自檔案a,最後表示目標檔案b。即grep命令從b中選取a中不存在的行。

tee c命令建立檔案c,wc -l命令統計行數。

經典shell面試題整理

一 取出 etc passwd檔案中shell出現的次數 問題 下面是乙個 etc passwd檔案的部分內容。題目要求取出shell並統計次數,shell是指後面的 bin bash,sbin nologin等,如下面 bin bash出現12次,sbin nologin出現3次。hyn x 52...

經典面試題整理

new delete是c 關鍵字需要編譯器支援,malloc free是庫函式,需要庫支援 new 無需指定申請的大小,系統自動識別,並返回相應的物件指標,malloc需要指定申請記憶體的大小並且返回值為void 型別需要進行強制轉換。首先確定三次握手是什麼,然後客戶端和服務端都需要維護乙個序列號這...

經典shell面試題

script argument 例子 顯示檔名稱指令碼 show.sh file1.txt cat show.sh bin bash cat 1 第乙個引數 1,第二個引數 2 例子 指令碼會複製檔案 arg1 到目標位址 arg2 copy.sh file1.txt tmp cat copy.sh...