1. 統計一個目錄下所有普通檔案的總行數
#實用情境:畢業設計時,需要統計自己的程式碼數#
方案一:find . -type f -name "*.c" -exec cat {} \; | grep -v '^$' | wc -l
解釋:find . -type f -name "*.c" 尋找目前的目錄下所有以.c結尾的檔案,如果不考慮檔案類型,可以直接實用find . -type f即可。 -exec cat {} \; 是將找到的檔案採用cat命令輸出; grep -v '^$' 是將不是空行的內容進行統計,如果是空行就不統計,它相當於一個過濾器。 wc -l 統計輸出來的代碼的行數。如果不需要對空行進行過濾的話,可以省去grep -v '^$'
方案二:find . -type f -exec wc -l {} \; | awk '{sum+=$1}END{print sum}'
解釋:find命令同方案一。-exec wc -l 是指將找到的檔案依次計算其中的行數,此時如果輸出的話,會輸出類似於
22 main.c
43 head1.h
67 head1.c
所以還要採用awk將第一列進行相加,由sum+=$1,很明顯,比較容易理解awk的含義。但此種方法沒有對空行進行過濾。
方案三:find . -type f | xargs wc -l
解釋:使用xargs與方案二的差異在於在使用find命令的-exec選項處理匹配到的檔案時,
find命令將所有匹配到的檔案一起傳遞給exec執行。但有些系統對能夠傳遞給exec的命令長度有限制,這樣在find命令運行幾分鐘之後,就會出現
溢出錯誤。錯誤資訊通常是“參數列太長”或“參數列溢出”。這就是xargs命令的用處所在,特別是與find命令一起使用。
find命令把匹配到的檔案傳遞給xargs命令,而xargs命令每次只擷取一部分檔案而不是全部,不像-exec選項那樣。這樣它可以先處理最先擷取的一部分檔案,然後是下一批,並如此繼續下去。
對於方案三,系統會顯示每個檔案的行數,然後顯示總行數:
14 ./main.c
8 ./abc.c
8 ./folder/main.c
8 ./folder/shaoning/test.c
38 總用量
思考題:(重點是理解xargs的含義)
知道指定尾碼名的檔案總個數命令:(得到的是html檔案的數目)
find . -name "*.html" | wc -l
知道一個目錄下代碼總行數以及單個檔案行數:(得到的是每個及所有html檔案中內容的行數)
find . -name "*.html" | xargs wc -l