新聞中心
在我們使用Linux操作系統(tǒng)的過程中,經(jīng)常會(huì)遇到需要查找某個(gè)關(guān)鍵詞在文件中出現(xiàn)的次數(shù)的情況,而我們通常會(huì)使用in命令來完成這個(gè)任務(wù)。然而,有些情況下我們可能會(huì)發(fā)現(xiàn)自己不能夠使用in命令,這時(shí)我們?cè)撛趺崔k呢?

目前創(chuàng)新互聯(lián)建站已為上1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、洱源網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
1. 使用grep命令
grep命令是Linux中非常常用的一個(gè)命令,它可以用來搜索指定的字符串或者正則表達(dá)式,并將包含該字符串或者匹配該正則表達(dá)式的行輸出。因此,我們可以使用grep命令來完成查找某個(gè)關(guān)鍵詞在文件中出現(xiàn)的次數(shù)的任務(wù)。
具體做法是,在終端中輸入以下命令:
grep -o “要查找的關(guān)鍵詞” 文件名 | wc -l
其中,“-o”選項(xiàng)表示只輸出匹配到的內(nèi)容,“wc”命令用來計(jì)算行數(shù),從而得到要查找的關(guān)鍵詞在文件中出現(xiàn)的次數(shù)。
2. 使用awk命令
awk命令是一個(gè)強(qiáng)大的文本處理工具,它可以在文本文件中查找和處理信息,類似于編程語(yǔ)言中的腳本語(yǔ)言。因此,我們也可以使用awk命令來完成查找某個(gè)關(guān)鍵詞在文件中出現(xiàn)的次數(shù)的任務(wù)。
具體做法是,在終端中輸入以下命令:
awk ‘/要查找的關(guān)鍵詞/{count++}END{print count}’ 文件名
其中,“/要查找的關(guān)鍵詞/”表示匹配到要查找的關(guān)鍵詞時(shí)執(zhí)行大括號(hào)中的代碼,“count++”表示每匹配到關(guān)鍵詞就將計(jì)數(shù)器加一,“END{print count}”表示在匹配結(jié)束后輸出計(jì)數(shù)器中的值。
3. 使用sed命令
sed命令也是一個(gè)文本處理工具,它可以對(duì)文本文件進(jìn)行替換、刪除、插入等操作。同樣,我們也可以使用sed命令來完成查找某個(gè)關(guān)鍵詞在文件中出現(xiàn)的次數(shù)的任務(wù)。
具體做法是,在終端中輸入以下命令:
sed -n “s/要查找的關(guān)鍵詞/&/gp” 文件名 | wc -l
其中,“-n”表示只輸出執(zhí)行sed命令后得到的結(jié)果,“s/要查找的關(guān)鍵詞/&/gp”表示將匹配到的關(guān)鍵詞替換成自身(即不做替換,只是為了統(tǒng)計(jì)關(guān)鍵詞出現(xiàn)的次數(shù)),“| wc -l”表示通過管道將輸出結(jié)果傳遞給“wc”命令來計(jì)算行數(shù),從而得到要查找的關(guān)鍵詞在文件中出現(xiàn)的次數(shù)。
在Linux操作系統(tǒng)中,雖然in命令是最常用的查找關(guān)鍵詞在文件中出現(xiàn)次數(shù)的命令之一,但是我們也可以使用grep、awk或者sed等命令來完成同樣的任務(wù)。因此,當(dāng)我們無法使用in命令時(shí),可以嘗試使用其他命令來完成相同的任務(wù),以增強(qiáng)自己的Linux操作技能。
相關(guān)問題拓展閱讀:
- linux命令的格式化命令是什么?
linux命令的格式化命令是什么?
如果一個(gè)名稱用%括起來,那么就是用的它的賦值,而不是本身的字母
比如
echo timeecho %time%
以上兩個(gè)前者顯示time這個(gè)字母,后者顯示系統(tǒng)時(shí)間 19:42:12:02
還有%diskdiver%=系統(tǒng)盤等。
可以用set自己設(shè)定,有一些是系統(tǒng)默認(rèn)的比容上面說的time;diskdiver
FOR這條命令基本上都被用來處理文本,我們這次除了要說他處理文本的作用外還要講他的其他一些好用的功能!
看看他的基本格式(這里我引用的是批處理中的格式,直接在命令行只需要一個(gè)%號(hào))
FOR 參數(shù) %%變量名 IN (相關(guān)文件或命令) DO 執(zhí)行的命令
參數(shù):FOR有4個(gè)參數(shù) /d /l /r /f 他們的作用我在下面用例子解釋
%%變量名 :這個(gè)變量名可以是小寫a-z或者大寫A-Z,他們區(qū)分大小寫哦~
FOR會(huì)把每個(gè)讀取到的值給他!
IN:命令的格式,照寫就是了!
(相關(guān)文件或命令) :FOR要把什么東西讀取然后賦值給變量,不懂的話看下面的例子
do:命令的格式,照寫就是了!
執(zhí)行的命令:對(duì)每個(gè)變量的值要執(zhí)行什么操作就寫在這.
看不懂我的這些說明,可以在CMD輸入for /?看系統(tǒng)提供的幫助!我這里也給出來吧,大家對(duì)照
FOR %%variable IN (set) DO command
%%variable 指定一個(gè)單一字母可替換的參數(shù)。
(set) 指定一個(gè)或一組文件??梢允褂猛ㄅ浞?。
command 指定對(duì)每個(gè)文件執(zhí)行的命令。
command-parameters
為特定命令指定參數(shù)或命令行開關(guān)。
現(xiàn)在開始講每個(gè)參數(shù)的意思
/d
僅為目錄
如果 Set (也就是我上面寫的 “相關(guān)文件或命令”) 包含通配符(* 和 ?),將對(duì)與 Set 相匹配的每個(gè)目錄(而不是指定目錄中的文件組)執(zhí)行指定的 Command。
這個(gè)參數(shù)其實(shí)我也沒弄太懂…有錯(cuò)誤希望各位糾正!
系統(tǒng)鄭旅戚幫助的格式:FOR /D %%variable IN (set) DO command
他主要用于目錄搜索,不會(huì)搜索文件,看這樣的例子
@echo off
for /d %%i in (*) do @echo %%i
pause
把他保存放在C盤根目錄執(zhí)行,就會(huì)把C盤目錄下的全部目錄名字打印出來,而文件名字一個(gè)也不顯示!
在來一個(gè)鎮(zhèn)李,比如我們要把當(dāng)前路徑下文件夾的名字只有1-3個(gè)字母的打出來
@echo off
for /d %%i in (???) do @echo %%i
pause
這樣的話如果你當(dāng)前目錄下有目錄名字只有1-3個(gè)字母的,就會(huì)顯示出來,沒有就不顯示了
這里解釋下*號(hào)和?號(hào)的作用,*號(hào)表示任意N個(gè)字符,而?號(hào)只表示任意一個(gè)字符
知道作用了,給大喊陵家個(gè)思考題目!
@echo off
for /d %%i in (window?) do @echo %%i
pause
保存到C盤下執(zhí)行,會(huì)顯示什么呢?自己看吧!
/D參數(shù)只能顯示當(dāng)前目錄下的目錄名字,這個(gè)大家要注意!
/R
遞歸
進(jìn)入根目錄樹 Path,在樹的每個(gè)目錄中執(zhí)行 for 語(yǔ)句。如果在 /R 后沒有指定目錄,則認(rèn)為是當(dāng)前目錄。如果 Set 只是一個(gè)句點(diǎn) (.),則只枚舉目錄樹。
系統(tǒng)幫助的格式:FOR /R path> %%variable IN (set) DO command
上面我們知道,/D只能顯示當(dāng)前路徑下的目錄名字,那么現(xiàn)在這個(gè)/R也是和目錄有關(guān),他能干嘛呢?放心他比/D強(qiáng)大多了!
他可以把當(dāng)前或者你指定路徑下的文件名字全部讀取,注意是文件名字,有什么用看例子!
@echo off
for /r c:\ %%i in (*.exe) do @echo %%i
pause
咋們把這個(gè)BAT保存到D盤隨便哪里然后執(zhí)行,我會(huì)就會(huì)看到,他把C盤根目錄,和每個(gè)目錄的子目錄下面全部的EXE文件都列出來了!!!!
再來一個(gè)
@echo off
for /r %%i in (*.exe) do @echo %%i
pause
參數(shù)不一樣了吧!這個(gè)命令前面沒加那個(gè)C:\也就是搜索路徑,這樣他就會(huì)以當(dāng)前目錄為搜索路徑,比如你這個(gè)BAT你把他防災(zāi)d:\test目錄下執(zhí)行,那么他就會(huì)把D:\test目錄和他下面的子目錄的全部EXE文件列出來!!!
這個(gè)參數(shù)大家因該理解了吧!還是滿好玩的命令!
/L
迭代數(shù)值范圍
使用迭代變量設(shè)置起始值 (Start#),然后逐步執(zhí)行一組范圍的值,直到該值超過所設(shè)置的終止值 (End#)。/L 將通過對(duì) Start# 與 End# 進(jìn)行比較來執(zhí)行迭代變量。如果 Start# 小于 End#,就會(huì)執(zhí)行該命令。如果迭代變量超過 End#,則命令解釋程序退出此循環(huán)。還可以使用負(fù)的 Step# 以遞減數(shù)值的方式逐步執(zhí)行此范圍內(nèi)的值。例如,(1,1,5) 生成序列,而 (5,-1,1) 則生成序列 ()。語(yǔ)法是:
系統(tǒng)幫助的格式:for /L %% Variable in (Start#,Step#,End#) do Command
看著這說明有點(diǎn)暈吧!咋們看例子就不暈了!
@echo off
for /l %%i in (1,1,5) do @echo %%i
pause
保存執(zhí)行看效果,他會(huì)打印從這樣5個(gè)數(shù)字
(1,1,5)這個(gè)參數(shù)也就是表示從1開始每次加1直到5終止!
大會(huì)暈,就打印個(gè)數(shù)字有P用…好的滿足大家,看這個(gè)例子
@echo off
for /l %%i in (1,1,5) do start cmd
pause
執(zhí)行后是不是嚇了一跳,怎么多了5個(gè)CMD窗口,呵呵!如果把那個(gè) (1,1,5)改成 (1,1,65535)會(huì)有什么結(jié)果,我先告訴大家,會(huì)打開65535個(gè)CMD窗口….這么多你不死機(jī)算你強(qiáng)!
當(dāng)然我們也可以把那個(gè)start cmd改成md %%i 這樣就會(huì)建立指定個(gè)目錄了!!!名字為
看完這個(gè)被我賦予破壞性質(zhì)的參數(shù)后,我們來看最后一個(gè)參數(shù)
/f
\迭代及文件解析
使用文件解析來處理命令輸出、字符串及文件內(nèi)容。使用迭代變量定義要檢查的內(nèi)容或字符串,并使用各種 ParsingKeywords 選項(xiàng)進(jìn)一步修改解析方式。使用 ParsingKeywords 令牌選項(xiàng)指定哪些令牌應(yīng)該作為迭代變量傳遞。請(qǐng)注意:在沒有使用令牌選項(xiàng)時(shí),/F 將只檢查之一個(gè)令牌。
文件解析過程包括讀取輸出、字符串或文件內(nèi)容,將其分成獨(dú)立的文本行以及再將每行解析成零個(gè)或更多個(gè)令牌。然后通過設(shè)置為令牌的迭代變量值,調(diào)用 for 循環(huán)。默認(rèn)情況下,/F 傳遞每個(gè)文件每一行的之一個(gè)空白分隔符號(hào)。跳過空行。
系統(tǒng)幫助的格式:
for /F “ParsingKeywords” %% Variable in (FileNameSet) do Command
有沒有發(fā)現(xiàn)這個(gè)參數(shù)說明比上面幾個(gè)都多…沒辦法,人們用FOR命令主要也就是用/f參數(shù),FOR的主場(chǎng)啊!大家得好好看!
先來解釋下那個(gè)多出來的”ParsingKeywords”
他表示4個(gè)參數(shù)
eol=c指一個(gè)行注釋字符的結(jié)尾(就一個(gè))
skip=n指在文件開始時(shí)忽略的行數(shù)。
delims=xxx指分隔符集。這個(gè)替換了空格和跳格鍵的
默認(rèn)分隔符集。
tokens=x,y,m-n – 指每行的哪一個(gè)符號(hào)被傳遞到每個(gè)迭代
的 for 本身。這會(huì)導(dǎo)致額外變量名稱的分配。m-n
格式為一個(gè)范圍。通過 nth 符號(hào)指定 mth。如果
符號(hào)字符串中的最后一個(gè)字符星號(hào),
那么額外的變量將在最后一個(gè)符號(hào)解析之后
分配并接受行的保留文本。
usebackq指定新語(yǔ)法已在下類情況中使用:
在作為命令執(zhí)行一個(gè)后引號(hào)的字符串并且一個(gè)單
引號(hào)字符為文字字符串命令并允許在 filenameset
中使用雙引號(hào)擴(kuò)起文件名稱。
先別暈了!我這就舉個(gè)例子幫助大家來理解這些參數(shù)!
usebackq這個(gè)參數(shù)不用理解了,系統(tǒng)默認(rèn)會(huì)給我們加上!
為了能使用這個(gè)例子,我們先新建一個(gè)文本文件,在里面打上這些內(nèi)容保存為test.txt:
;郁悶啊!
您好! 歡迎來到, 非常批處理
我們的網(wǎng)站 bbs.verybat.org
完畢!
@echo off
FOR /F “eol=; tokens=1 delims= ” %%i in (test.txt) do @echo %%i
pause
我們把這個(gè)BAT保存到和你的test.txt相同的目錄下面然后執(zhí)行
我們會(huì)看到屏幕上會(huì)顯示
您好!
我們的網(wǎng)站
完畢!
為什么會(huì)這樣?我來解釋
這個(gè)命令會(huì)讀取在當(dāng)前目錄下名為test.txt文件中的內(nèi)容,將每一行的內(nèi)容賦值給變量%%i,忽略掉以;號(hào)開頭的行,并且以空格做為分隔符號(hào),打印每行以空格做分隔符號(hào)的之一列
結(jié)果就是這樣了!!
如果改成
當(dāng)然我們想要把全部文件內(nèi)容直接打印出來就可以這樣
@echo off
FOR /F “delims=” %%i in (test.txt) do @echo %%i
pause
另外/F參數(shù)還可以以輸出命令的結(jié)果看這個(gè)例子
@echo off
FOR /F “delims=” %%i in (‘net user’) do @echo %%i
pause
這樣你本機(jī)全部帳號(hào)名字就出來了把擴(kuò)號(hào)內(nèi)的內(nèi)容用兩個(gè)單引號(hào)引起來就表示那個(gè)當(dāng)命令執(zhí)行,FOR會(huì)返回命令的每行結(jié)果,加那個(gè)”delims=” 是為了讓我空格的行能整行顯示出來,不加就只顯示空格左邊一列!
關(guān)于linux 沒有in命令的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
成都創(chuàng)新互聯(lián)建站主營(yíng):成都網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、網(wǎng)站改版的網(wǎng)站建設(shè)公司,提供成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、成都網(wǎng)站推廣、成都網(wǎng)站優(yōu)化seo、響應(yīng)式移動(dòng)網(wǎng)站開發(fā)制作等網(wǎng)站服務(wù)。
名稱欄目:掌握Linux必備:沒有in命令怎么辦?(linux沒有in命令)
文章網(wǎng)址:http://fisionsoft.com.cn/article/djcjode.html


咨詢
建站咨詢
