問題:下面是乙個/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...