Linux命令行組合:grep和wc命令的強(qiáng)大用法
Linux grep (global regular expression) 命令用于查找文件里符合條件的字符串或正則表達(dá)式。grep 指令用于查找內(nèi)容包含指定的范本樣式的文件,如果發(fā)現(xiàn)某文件的內(nèi)容符合所指定的范本樣式,預(yù)設(shè) grep 指令會(huì)把含有范本樣式的那一列顯示出來。若不指定任何文件名稱,或是所給予的文件名為 -,則 grep 指令會(huì)從標(biāo)準(zhǔn)輸入設(shè)備讀取數(shù)據(jù)。
Linux命令行工具中的grep和wc命令是一個(gè)非常強(qiáng)大的組合,可以用于在文件集合中搜索匹配特定模式的行并計(jì)算匹配行數(shù)。
常見用法:
# 查找某文件夾下所有文件中某個(gè)字符的個(gè)數(shù)
grep 'xxx' * | wc -l
# 查看某文件夾下文件的個(gè)數(shù)
ls -l |grep "^-"|wc -l
# 或
find ./company -type f | wc -l
# 查看某文件夾下文件的個(gè)數(shù),包括子文件夾里的。
ls -lR|grep "^-"|wc -l
# 查看某文件夾下文件夾的個(gè)數(shù),包括子文件夾里的。
ls -lR|grep "^d"|wc -l
以上內(nèi)容說明如下:
ls -l
長列表輸出該目錄下文件信息(注意這里的文件,不同于一般的文件,可能是目錄、鏈接、設(shè)備文件等)
grep "^-"
這里將長列表輸出信息過濾一部分,只保留一般文件,如果只保留目錄就是 ^d
wc -l
統(tǒng)計(jì)輸出信息的行數(shù),因?yàn)橐呀?jīng)過濾得只剩一般文件了,所以統(tǒng)計(jì)結(jié)果就是一般文件信息的行數(shù),又由于一行信息對應(yīng)一個(gè)文件,所以也就是文件的個(gè)數(shù)。
下面舉幾個(gè)詳細(xì)的例子來說明這個(gè)組合的用法。
例1:搜索文件中包含特定字符串的行數(shù)
假設(shè)我們有一個(gè)包含一些文本文件的目錄,我們想要知道每個(gè)文件中包含特定字符串的行數(shù)。我們可以使用以下命令:
grep -r "search_string" ./ | wc -l
這個(gè)命令會(huì)遞歸地搜索當(dāng)前目錄下的所有文件,查找包含"search_string"的行,并使用wc命令計(jì)算匹配的行數(shù)。輸出結(jié)果將顯示每個(gè)文件中匹配的行數(shù)。
例2:搜索文件中不包含特定字符串的行數(shù)
有時(shí)候我們可能想要搜索文件中不包含特定字符串的行數(shù)。這可以通過使用grep命令的-v選項(xiàng)來實(shí)現(xiàn)。例如:
grep -v "exclude_string" * | wc -l
遞歸搜索當(dāng)前目錄下的所有文件,查找不包含"exclude_string"的行,并計(jì)算匹配的行數(shù)。輸出結(jié)果將顯示所有文件中不包含"exclude_string"的行數(shù)。
例3:搜索文件中包含特定模式的行數(shù)
除了搜索具體的字符串,我們還可以使用正則表達(dá)式來搜索匹配特定模式的行。例如:
grep -E "pattern1|pattern2" * | wc -l
遞歸搜索當(dāng)前目錄下的所有文件,查找匹配"pattern1"或"pattern2"的行,并計(jì)算匹配的行數(shù)。輸出結(jié)果將顯示所有文件中匹配模式的行數(shù)。
這些例子只是grep和wc命令組合的一小部分用法。通過結(jié)合不同的選項(xiàng)和參數(shù),我們可以實(shí)現(xiàn)更復(fù)雜的搜索和計(jì)數(shù)任務(wù)。
下面再舉幾個(gè)更復(fù)雜的例子來說明grep和wc命令的組合用法。
例4:搜索文件中匹配多個(gè)關(guān)鍵字的行數(shù)
如果我們想要搜索文件中同時(shí)匹配多個(gè)關(guān)鍵字的行數(shù),我們可以使用grep命令的-E選項(xiàng)來實(shí)現(xiàn)多個(gè)選項(xiàng)間的邏輯“AND”關(guān)系。例如:
grep -E "keyword1|keyword2|keyword3" * | wc -l
遞歸搜索當(dāng)前目錄下的所有文件,查找同時(shí)包含"keyword1"、"keyword2"和"keyword3"的所有行,并計(jì)算匹配的行數(shù)。輸出結(jié)果將顯示所有文件中同時(shí)匹配所有關(guān)鍵字的行數(shù)。
例5:搜索文件中匹配模式的行并重定向到指定文件
我們可以將grep命令的輸出重定向到指定文件中,以便將匹配的行保存到文件中進(jìn)行進(jìn)一步處理。例如:
grep "search_string" ./ | wc -l > output.txt
遞歸搜索當(dāng)前目錄下的所有文件,查找包含"search_string"的行,并使用wc命令計(jì)算匹配的行數(shù)。然后,將輸出結(jié)果重定向到名為"output.txt"的文件中。
例6:搜索文件中匹配模式的行并輸出匹配行的行號
我們可以使用grep命令的-n選項(xiàng)來輸出匹配行的行號。例如:
grep -n "search_string" ./
遞歸搜索當(dāng)前目錄下的所有文件,查找包含"search_string"的行,并輸出匹配行的行號。
這些例子展示了grep和wc命令組合的更多用法和功能。根據(jù)不同的需求,我們可以靈活運(yùn)用這些選項(xiàng)和參數(shù)來滿足特定的搜索和計(jì)數(shù)任務(wù)。