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