真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

linux過(guò)濾中文中命令 linux系統(tǒng)中哪些工具可以對(duì)文本輸出進(jìn)行過(guò)濾

Linux下常用文本處理命令

Linux下常用文本處理命令大全

成都創(chuàng)新互聯(lián)公司為您提適合企業(yè)的網(wǎng)站設(shè)計(jì)?讓您的網(wǎng)站在搜索引擎具有高度排名,讓您的網(wǎng)站具備超強(qiáng)的網(wǎng)絡(luò)競(jìng)爭(zhēng)力!結(jié)合企業(yè)自身,進(jìn)行網(wǎng)站設(shè)計(jì)及把握,最后結(jié)合企業(yè)文化和具體宗旨等,才能創(chuàng)作出一份性化解決方案。從網(wǎng)站策劃到網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì), 我們的網(wǎng)頁(yè)設(shè)計(jì)師為您提供的解決方案。

Linux下面有很多經(jīng)典的非常有用的命令,其中處理文本的命令就有很多。下面就讓我們一起看看這些經(jīng)典的Linux文本處理命令有哪些吧。

一. sort

文件排序, 通常用在管道中當(dāng)過(guò)濾器來(lái)使用. 這個(gè)命令可以依據(jù)指定的關(guān)鍵字或指定的字符位置, 對(duì)文件行進(jìn)行排序. 使用-m選項(xiàng), 它將會(huì)合并預(yù)排序的輸入文件. 想了解這個(gè)命令的全部參數(shù)請(qǐng)參考這個(gè)命令的info頁(yè).

二. tsort

拓?fù)渑判? 讀取以空格分隔的有序?qū)? 并且依靠輸入模式進(jìn)行排序.

三. uniq

這個(gè)過(guò)濾器將會(huì)刪除一個(gè)已排序文件中的重復(fù)行. 這個(gè)命令經(jīng)常出現(xiàn)在sort命令的管道后邊.

四. expand, unexpand

expand命令將會(huì)把每個(gè)tab轉(zhuǎn)化為一個(gè)空格. 這個(gè)命令經(jīng)常用在管道中.

unexpand命令將會(huì)把每個(gè)空格轉(zhuǎn)化為一個(gè)tab. 效果與expand命令相反.

五. cut

一個(gè)從文件中提取特定域的工具. 這個(gè)命令與awk中使用的print $N命令很相似, 但是更受限. 在腳本中使用cut命令會(huì)比使用awk命令來(lái)得容易一些. 最重要的選項(xiàng)就是-d(字段定界符)和-f(域分隔符)選項(xiàng).

六. paste

將多個(gè)文件, 以每個(gè)文件一列的形式合并到一個(gè)文件中, 合并后文件中的每一列就是原來(lái)的一個(gè)文件. 與cut結(jié)合使用, 經(jīng)常用于創(chuàng)建系統(tǒng)log文件.

七. join

這個(gè)命令與paste命令屬于同類(lèi)命令. 但是它能夠完成某些特殊的目地. 這個(gè)強(qiáng)力工具能夠以一種特殊的形式來(lái)合并兩個(gè)文件, 這種特殊的形式本質(zhì)上就是一個(gè)關(guān)聯(lián)數(shù)據(jù)庫(kù)的簡(jiǎn)單版本.

join命令只能夠操作兩個(gè)文件. 它可以將那些具有特定標(biāo)記域(通常是一個(gè)數(shù)字標(biāo)簽)的行合并起來(lái), 并且將結(jié)果輸出到stdout. 被加入的文件應(yīng)該事先根據(jù)標(biāo)記域進(jìn)行排序以便于能夠正確的匹配.

八. head

把文件的頭部?jī)?nèi)容打印到stdout上(默認(rèn)為10行, 可以自己修改). 這個(gè)命令有一些比較有趣的選項(xiàng).

九. tail

將一個(gè)文件結(jié)尾部分的內(nèi)容輸出到stdout中(默認(rèn)為10行). 通常用來(lái)跟蹤一個(gè)系統(tǒng)logfile的.修改情況, 如果使用-f選項(xiàng)的話(huà), 這個(gè)命令將會(huì)繼續(xù)顯示添加到文件中的行.

十. wc

wc可以統(tǒng)計(jì)文件或I/O流中的”單詞數(shù)量”:

十一. fold

將輸入按照指定寬度進(jìn)行折行. 這里有一個(gè)非常有用的選項(xiàng)-s, 這個(gè)選項(xiàng)可以使用空格進(jìn)行斷行(譯者: 事實(shí)上只有外文才需要使用空格斷行, 中文是不需要的)(請(qǐng)參考例子 12-23和例子 A-1).

十二. fmt

一個(gè)簡(jiǎn)單的文件格式器, 通常用在管道中, 將一個(gè)比較長(zhǎng)的文本行輸出進(jìn)行”折行”.

十三. col

這個(gè)命令用來(lái)濾除標(biāo)準(zhǔn)輸入的反向換行符號(hào). 這個(gè)工具還可以將空白用等價(jià)的tab來(lái)替換. col工具最主要的應(yīng)用還是從特定的文本處理工具中過(guò)濾輸出, 比如groff和tbl. (譯者: 主要用來(lái)將man頁(yè)轉(zhuǎn)化為文本.)

十四. column

列格式化工具. 通過(guò)在合適的位置插入tab, 這個(gè)過(guò)濾工具會(huì)將列類(lèi)型的文本轉(zhuǎn)化為”易于打印”的表格式進(jìn)行輸出.

十五. colrm

列刪除過(guò)濾器. 這個(gè)工具將會(huì)從文件中刪除指定的列(列中的字符串)并且寫(xiě)到文件中, 如果指定的列不存在, 那么就回到stdout. colrm 2 4 filename將會(huì)刪除filename文件中每行的第2到第4列之間的所有字符. p="" /filename將會(huì)刪除filename文件中每行的第2到第4列之間的所有字符.

Caution: 如果這個(gè)文件包含tab和不可打印字符, 那將會(huì)引起不可預(yù)期的行為. 在這種情況下, 應(yīng)該通過(guò)管道的手段使用expand和unexpand來(lái)預(yù)處理colrm.

十六. nl

計(jì)算行號(hào)過(guò)濾器. nl filename將會(huì)把filename文件的所有內(nèi)容都輸出到stdout上, 但是會(huì)在每個(gè)非空行的前面加上連續(xù)的行號(hào). 如果沒(méi)有filename參數(shù), 那么就操作stdin.

nl命令的輸出與cat -n非常相似, 然而, 默認(rèn)情況下nl不會(huì)列出空行.

十七. pr

格式化打印過(guò)濾器. 這個(gè)命令會(huì)將文件(或stdout)分頁(yè), 將它們分成合適的小塊以便于硬拷貝打印或者在屏幕上瀏覽. 使用這個(gè)命令的不同的參數(shù)可以完成好多任務(wù), 比如對(duì)行和列的操作, 加入行, 設(shè)置頁(yè)邊, 計(jì)算行號(hào), 添加頁(yè)眉, 合并文件等等. pr命令集合了許多命令的功能, 比如nl, paste, fold, column, 和expand.

pr -o 5 –width=65 fileZZZ | more 這個(gè)命令對(duì)fileZZZ進(jìn)行了比較好的分頁(yè), 并且打印到屏幕上. 文件的縮進(jìn)被設(shè)置為5, 總寬度設(shè)置為65.

一個(gè)非常有用的選項(xiàng)-d, 強(qiáng)制隔行打印(與sed -G效果相同).

十八. gettext

GNU gettext包是專(zhuān)門(mén)用來(lái)將程序的輸出翻譯或者本地化為不同國(guó)家語(yǔ)言的工具集. 在最開(kāi)始的時(shí)候僅僅支持C語(yǔ)言, 現(xiàn)在已經(jīng)支持了相當(dāng)數(shù)量的其它程序語(yǔ)言和腳本語(yǔ)言.

想要查看gettext程序如何在shell腳本中使用. 請(qǐng)參考info頁(yè).

十九. msgfmt

一個(gè)產(chǎn)生二進(jìn)制消息目錄的程序. 這個(gè)命令主要用來(lái)本地化.

二十. iconv

一個(gè)可以將文件轉(zhuǎn)化為不同編碼格式(字符集)的工具. 這個(gè)命令主要用來(lái)本地化.

二十一. recode

可以認(rèn)為這個(gè)命令是上邊iconv命令的專(zhuān)業(yè)版本. 這個(gè)非常靈活的并可以把整個(gè)文件都轉(zhuǎn)換為不同編碼格式的工具并不是Linux標(biāo)準(zhǔn)安裝的一部分.

二十二. TeX, gs

TeX和Postscript都是文本標(biāo)記語(yǔ)言, 用來(lái)對(duì)打印和格式化的視頻顯示進(jìn)行預(yù)拷貝.

TeX是Donald Knuth精心制作的排版系統(tǒng). 通常情況下, 通過(guò)編寫(xiě)腳本的手段來(lái)把所有的選項(xiàng)和參數(shù)封裝起來(lái)一起傳到標(biāo)記語(yǔ)言中是一件很方便的事情.

Linux命令之篩選條件

grep (過(guò)濾)

過(guò)濾需要的內(nèi)容,

-v 需要排除的內(nèi)容,

-i不分辨大小寫(xiě),

-n匹配的內(nèi)容在其行首顯示行號(hào),

-A (after)顯示匹配字符串及其后n行,

-B (before)顯示匹配字符串及其前n行,

-C(context)顯示匹配字符串

下邊是想湊字?jǐn)?shù)的啦啦

linux下編程實(shí)現(xiàn)用戶(hù)命令過(guò)濾功能

你可以這樣做:

(1)為Server的那些使用者建立單獨(dú)的賬戶(hù),例如:user01、user02....等等(可以給每個(gè)人建立一個(gè)單獨(dú)的賬戶(hù)。當(dāng)然,為了使系統(tǒng)中的賬戶(hù)不至于太多而導(dǎo)致難以管理,也可以按照他們所在的部門(mén)、項(xiàng)目組(或工作組)、或是其它分類(lèi)方式去建立賬戶(hù))。

(2)對(duì)每個(gè)賬戶(hù)下的$HOME/.profile文件或者是$HOME/.cshrc文件(視不同用戶(hù)的SHELL來(lái)決定,例如:bsh和sh就是.profile,csh就是.cshrc),用

chown root:root ... (例如: chown root:root .cshrc)

命令將它們改成root用戶(hù)及屬組所有,只有root用戶(hù)才可以更改它們。

(3)在每個(gè)用戶(hù)的$HOME/.profile或是$HOME/.cshrc等shell環(huán)境配置文件中,將你認(rèn)為是危險(xiǎn)的命令做以下的轉(zhuǎn)換:

alias 命令名='echo 管理員不運(yùn)行執(zhí)行該命令'

例如: alias format='echo 管理員不運(yùn)行執(zhí)行該命令'

這樣這些用戶(hù)就無(wú)法執(zhí)行你限定的命令,執(zhí)行之后都顯示“管理員不運(yùn)行執(zhí)行該命令”。

如果覺(jué)得改.profile或是.cshrc文件不保險(xiǎn),還可以在每個(gè)用戶(hù)的$HOME下建立.login文件,也用上述的方法將它改成root用戶(hù)屬組的,在里面加入

alias 命令名='echo 管理員不運(yùn)行執(zhí)行該命令'

效果更好。

----看到了你的問(wèn)題追加。我覺(jué)得要是大家都只能使用root賬戶(hù),那么這個(gè)系統(tǒng)的規(guī)劃是否合理?假如一定都要使用root賬戶(hù)的話(huà),對(duì)于每個(gè)用戶(hù)在鍵入命令的過(guò)程中,你很難去捕獲他們都正在敲入什么命令。只有等他們?cè)诿钚猩隙驾斎胪炅?,回?chē)確認(rèn)之后才可能去發(fā)現(xiàn)他們執(zhí)行的進(jìn)程。假如真有這樣的一個(gè)監(jiān)控程序在你的系統(tǒng)中,就算是監(jiān)控到了,那么那些進(jìn)程已經(jīng)開(kāi)始運(yùn)行了,對(duì)很多人來(lái)說(shuō)已經(jīng)是無(wú)法收拾了,只有及時(shí)的殺掉那些進(jìn)程了。建議你把敏感的命令給rename了算了,例如mv format frmt

----呵呵,你也夠執(zhí)著的。既然一定要寫(xiě)個(gè)程序,那我就說(shuō)說(shuō)大概的思路吧!具體的程序代碼你可以自己去寫(xiě),這樣也有些成就感。:)

不過(guò)我能保證,就算采用這樣的做法也不會(huì)取得什么好的效果,尤其是大家都使用root賬戶(hù)。我用unix類(lèi)操作系統(tǒng)近十年,聽(tīng)我一句勸告不會(huì)有什么害處??!

程序思路:

(1)定義你的敏感命令列表(可以賦值給一個(gè)字符串?dāng)?shù)組)。

(2)獲取你本人在系統(tǒng)中當(dāng)前的tty編號(hào),以及你自己的IP地址(你是從哪個(gè)IP地址發(fā)起的telnet?如果你本人使用Console,也需要如此)。

(3)按照你的敏感命令列表,循環(huán)檢測(cè)除了自己的tty及IP地址之外的,其它tty及IP地址發(fā)起的敏感命令進(jìn)程,如果發(fā)現(xiàn),立即予以kill -9。并向相應(yīng)的tty發(fā)送警告信息。

注意:這個(gè)循環(huán)是無(wú)限循環(huán);這個(gè)程序是一個(gè)守護(hù)進(jìn)程(Daemon)。除非接到進(jìn)程中止信號(hào),否則它將一直運(yùn)行。這樣做的缺點(diǎn)是,循環(huán)檢測(cè)并殺掉那些敏感進(jìn)程的過(guò)程并不能確保實(shí)時(shí)性,在發(fā)現(xiàn)相應(yīng)的進(jìn)程時(shí),那些進(jìn)程可能已經(jīng)運(yùn)行了一小段時(shí)間,盡管這段時(shí)間非常非常的短,但是也可能已經(jīng)產(chǎn)生了效力甚至是危害。不過(guò),這也是沒(méi)辦法的事情了。誰(shuí)要你非要這樣呢?

Linux運(yùn)維必學(xué)命令之文件過(guò)濾!Linux入門(mén)

熟悉Linux運(yùn)維工作的小伙伴們都知道,在Linux操作系統(tǒng)中,除了Cat、tac、more、less等命令之外,還有很多用于文本查看的命令,比如head、tail等,本文將為大家詳細(xì)的介紹一下。

cat:合并文件或查看文件內(nèi)容

tac:反向顯示文件內(nèi)容

more:分頁(yè)顯示文件內(nèi)容

less:分頁(yè)顯示文件內(nèi)容

head:顯示文件內(nèi)容頭部

tail:顯示文件內(nèi)容尾部

tailf:跟蹤日志文件

cut:從文本中提取一段文字并輸出

split:分割文件

paste:合并文件

sort:文本排序

join:按兩個(gè)文件的相同字段合并

uniq:去除重復(fù)行

wc:統(tǒng)計(jì)文件的行數(shù)、單詞數(shù)或字節(jié)數(shù)

iconv:轉(zhuǎn)換文件的編碼格式

dos2unix:將DOS格式文件轉(zhuǎn)換成UNIX格式

diff:比較兩個(gè)文件的不同

vimdiff:可視化比較工具

rev:反向輸出文件內(nèi)容

tr:替換或刪除字符

od:按不同進(jìn)制顯示文件

tee:多重定向

vi/vim:純文本編輯器

在用ssh登錄linux系統(tǒng)后,用grep過(guò)濾文件中中文,沒(méi)有返回結(jié)果

編碼不一致導(dǎo)致,過(guò)濾中文,保證你輸入過(guò)濾條件的中文編碼,必須和待過(guò)濾的中文編碼格式完全一樣。如果你使用的是xshell等客戶(hù)端ssh,可以在xshell客戶(hù)端選擇編碼。

Linux常用指令---grep(搜索過(guò)濾)(轉(zhuǎn))

Linux常用指令---grep(搜索過(guò)濾) (轉(zhuǎn))

Linux系統(tǒng)中g(shù)rep命令是一種強(qiáng)大的文本搜索工具,它能使用正則表達(dá)式搜索文本,并把匹?配的行打印出來(lái)。grep全稱(chēng)是Global?Regular?Expression?Print,表示全局正則表達(dá)式版本,它的使用權(quán)限是所有用戶(hù)。

grep的工作方式是這樣的,它在一個(gè)或多個(gè)文件中搜索字符串模板。如果模板包括空格,則必須被引用,模板后的所有字符串被看作文件名。搜索的結(jié)果被送到標(biāo)準(zhǔn)輸出,不影響原文件內(nèi)容。

grep可用于shell腳本,因?yàn)間rep通過(guò)返回一個(gè)狀態(tài)值來(lái)說(shuō)明搜索的狀態(tài),如果模板搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。我們利用這些返回值就可進(jìn)行一些自動(dòng)化的文本處理工作。

1.命令格式:

grep?[option]?pattern?file

2.命令功能:

用于過(guò)濾/搜索的特定字符??墒褂谜齽t表達(dá)式能多種命令配合使用,使用上十分靈活。

3.命令參數(shù):

-a???--text???#不要忽略二進(jìn)制的數(shù)據(jù)。???

-A顯示行數(shù)???--after-context=顯示行數(shù)???#除了顯示符合范本樣式的那一列之外,并顯示該行之后的內(nèi)容。???

-b???--byte-offset???#在顯示符合樣式的那一行之前,標(biāo)示出該行第一個(gè)字符的編號(hào)。???

-B顯示行數(shù)???--before-context=顯示行數(shù)???#除了顯示符合樣式的那一行之外,并顯示該行之前的內(nèi)容。???

-c????--count???#計(jì)算符合樣式的列數(shù)。???

-C顯示行數(shù)????--context=顯示行數(shù)或-顯示行數(shù)???#除了顯示符合樣式的那一行之外,并顯示該行之前后的內(nèi)容。???

-d?動(dòng)作??????--directories=動(dòng)作???#當(dāng)指定要查找的是目錄而非文件時(shí),必須使用這項(xiàng)參數(shù),否則grep指令將回報(bào)信息并停止動(dòng)作。???

-e范本樣式??--regexp=范本樣式???#指定字符串做為查找文件內(nèi)容的樣式。???

-E??????--extended-regexp???#將樣式為延伸的普通表示法來(lái)使用。???

-f規(guī)則文件??--file=規(guī)則文件???#指定規(guī)則文件,其內(nèi)容含有一個(gè)或多個(gè)規(guī)則樣式,讓grep查找符合規(guī)則條件的文件內(nèi)容,格式為每行一個(gè)規(guī)則樣式。???

-F???--fixed-regexp???#將樣式視為固定字符串的列表。???

-G???--basic-regexp???#將樣式視為普通的表示法來(lái)使用。???

-h???--no-filename???#在顯示符合樣式的那一行之前,不標(biāo)示該行所屬的文件名稱(chēng)。???

-H???--with-filename???#在顯示符合樣式的那一行之前,表示該行所屬的文件名稱(chēng)。???

-i????--ignore-case???#忽略字符大小寫(xiě)的差別。???

-l????--file-with-matches???#列出文件內(nèi)容符合指定的樣式的文件名稱(chēng)。???

-L???--files-without-match???#列出文件內(nèi)容不符合指定的樣式的文件名稱(chēng)。???

-n???--line-number???#在顯示符合樣式的那一行之前,標(biāo)示出該行的列數(shù)編號(hào)。???

-q???--quiet或--silent???#不顯示任何信息。???

-r???--recursive???#此參數(shù)的效果和指定“-d?recurse”參數(shù)相同。???

-s???--no-messages???#不顯示錯(cuò)誤信息。???

-v???--revert-match???#顯示不包含匹配文本的所有行。???

-V???--version???#顯示版本信息。???

-w???--word-regexp???#只顯示全字符合的列。???

-x????--line-regexp???#只顯示全列符合的列。???

-y???#此參數(shù)的效果和指定“-i”參數(shù)相同。

4.規(guī)則表達(dá)式:

grep的規(guī)則表達(dá)式:

^??#錨定行的開(kāi)始?如:'^grep'匹配所有以grep開(kāi)頭的行。????

$??#錨定行的結(jié)束?如:'grep$'匹配所有以grep結(jié)尾的行。????

.??#匹配一個(gè)非換行符的字符?如:'gr.p'匹配gr后接一個(gè)任意字符,然后是p。????

*??#匹配零個(gè)或多個(gè)先前字符?如:'*grep'匹配所有一個(gè)或多個(gè)空格后緊跟grep的行。????

.*???#一起用代表任意字符。???

[]???#匹配一個(gè)指定范圍內(nèi)的字符,如'[Gg]rep'匹配Grep和grep。????

[^]??#匹配一個(gè)不在指定范圍內(nèi)的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個(gè)字母開(kāi)頭,緊跟rep的行。????

\(..\)??#標(biāo)記匹配字符,如'\(love\)',love被標(biāo)記為1。????

\??????#錨定單詞的開(kāi)始,如:'\

\??????#錨定單詞的結(jié)束,如'grep\'匹配包含以grep結(jié)尾的單詞的行。????

x\{m\}??#重復(fù)字符x,m次,如:'0\{5\}'匹配包含5個(gè)o的行。????

x\{m,\}??#重復(fù)字符x,至少m次,如:'o\{5,\}'匹配至少有5個(gè)o的行。????

x\{m,n\}??#重復(fù)字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10個(gè)o的行。???

\w????#匹配文字和數(shù)字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零個(gè)或多個(gè)文字或數(shù)字字符,然后是p。???

\W????#\w的反置形式,匹配一個(gè)或多個(gè)非單詞字符,如點(diǎn)號(hào)句號(hào)等。???

\b????#單詞鎖定符,如:?'\bgrep\b'只匹配grep。??

POSIX字符:

為了在不同國(guó)家的字符編碼中保持一至,POSIX(The?Portable?Operating?System?Interface)增加了特殊的字符類(lèi),如[:alnum:]是[A-Za-z0-9]的另一個(gè)寫(xiě)法。要把它們放到[]號(hào)內(nèi)才能成為正則表達(dá)式,如[A-?Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符類(lèi)。

[:alnum:]????#文字?jǐn)?shù)字字符???

[:alpha:]????#文字字符???

[:digit:]????#數(shù)字字符???

[:graph:]????#非空字符(非空格、控制字符)???

[:lower:]????#小寫(xiě)字符???

[:cntrl:]????#控制字符???

[:print:]????#非空字符(包括空格)???

[:punct:]????#標(biāo)點(diǎn)符號(hào)???

[:space:]????#所有空白字符(新行,空格,制表符)???

[:upper:]????#大寫(xiě)字符???

[:xdigit:]???#十六進(jìn)制數(shù)字(0-9,a-f,A-F)??

5.使用實(shí)例:

實(shí)例1:查找指定進(jìn)程

命令:

ps?-ef|grep?svn

輸出:

[root@localhost?~]#?ps?-ef|grep?svn

root?4943???1??????0??Dec05?????00:00:00?svnserve?-d?-r?/opt/svndata/grape/

root?16867?16838??0?19:53?pts/0????00:00:00?grep?svn

[root@localhost?~]#

說(shuō)明:

第一條記錄是查找出的進(jìn)程;第二條結(jié)果是grep進(jìn)程本身,并非真正要找的進(jìn)程。

實(shí)例2:查找指定進(jìn)程個(gè)數(shù)

命令:

ps?-ef|grep?svn?-c

ps?-ef|grep?-c?svn

輸出:

[root@localhost?~]#?ps?-ef|grep?svn?-c

2

[root@localhost?~]#?ps?-ef|grep?-c?svn?

2

[root@localhost?~]#

說(shuō)明:

實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索

命令:

cat?test.txt?|?grep?-f?test2.txt

輸出:

[root@localhost?test]#?cat?test.txt?

hnlinux

peida.cnblogs.com

ubuntu

ubuntu?linux

redhat

Redhat

linuxmint

[root@localhost?test]#?cat?test2.txt?

linux

Redhat

[root@localhost?test]#?cat?test.txt?|?grep?-f?test2.txt

hnlinux

ubuntu?linux

Redhat

linuxmint

[root@localhost?test]#

說(shuō)明:

輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行

實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索?且顯示行號(hào)

命令:

cat?test.txt?|?grep?-nf?test2.txt

輸出:

[root@localhost?test]#?cat?test.txt?

hnlinux

peida.cnblogs.com

ubuntu

ubuntu?linux

redhat

Redhat

linuxmint

[root@localhost?test]#?cat?test2.txt?

linux

Redhat

[root@localhost?test]#?cat?test.txt?|?grep?-nf?test2.txt

1:hnlinux

4:ubuntu?linux

6:Redhat

7:linuxmint

[root@localhost?test]#

說(shuō)明:

輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行,并顯示每一行的行號(hào)

實(shí)例5:從文件中查找關(guān)鍵詞

命令:

grep?'linux'?test.txt

輸出:

[root@localhost?test]#?grep?'linux'?test.txt?

hnlinux

ubuntu?linux

linuxmint

[root@localhost?test]#?grep?-n?'linux'?test.txt?

1:hnlinux

4:ubuntu?linux

7:linuxmint

[root@localhost?test]#

說(shuō)明:

實(shí)例6:從多個(gè)文件中查找關(guān)鍵詞

命令:

grep?'linux'?test.txt?test2.txt

輸出:

[root@localhost?test]#?grep?-n?'linux'?test.txt?test2.txt?

test.txt:1:hnlinux

test.txt:4:ubuntu?linux

test.txt:7:linuxmint

test2.txt:1:linux

[root@localhost?test]#?grep?'linux'?test.txt?test2.txt?

test.txt:hnlinux

test.txt:ubuntu?linux

test.txt:linuxmint

test2.txt:linux

[root@localhost?test]#

說(shuō)明:

多文件時(shí),輸出查詢(xún)到的信息內(nèi)容行時(shí),會(huì)把文件的命名在行最前面輸出并且加上":"作為標(biāo)示符

實(shí)例7:grep不顯示本身進(jìn)程

命令:

ps?aux|grep?\[s]sh

ps?aux?|?grep?ssh?|?grep?-v?"grep"

輸出:

[root@localhost?test]#?ps?aux|grep?ssh

root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd

root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0?

root??16901??0.0??0.0??61180???764?pts/0??S+???20:31???0:00?grep?ssh

[root@localhost?test]#?ps?aux|grep?\[s]sh]

[root@localhost?test]#?ps?aux|grep?\[s]sh

root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd

root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0?

[root@localhost?test]#?ps?aux?|?grep?ssh?|?grep?-v?"grep"

root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd

root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0

說(shuō)明:

實(shí)例8:找出已u開(kāi)頭的行內(nèi)容

命令:

cat?test.txt?|grep?^u

輸出:

[root@localhost?test]#?cat?test.txt?|grep?^u

ubuntu

ubuntu?linux

[root@localhost?test]#

說(shuō)明:

實(shí)例9:輸出非u開(kāi)頭的行內(nèi)容

命令:

cat?test.txt?|grep?^[^u]

輸出:

[root@localhost?test]#?cat?test.txt?|grep?^[^u]

hnlinux

peida.cnblogs.com

redhat

Redhat

linuxmint

[root@localhost?test]#

說(shuō)明:

實(shí)例10:輸出以hat結(jié)尾的行內(nèi)容

命令:

cat?test.txt?|grep?hat$

輸出:

[root@localhost?test]#?cat?test.txt?|grep?hat$

redhat

Redhat

[root@localhost?test]#

說(shuō)明:

實(shí)例11:輸出ip地址

命令:

ifconfig?eth0|grep?-E?"([0-9]{1,3}\.){3}[0-9]"

輸出:

[root@localhost?test]#?ifconfig?eth0|grep?"[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}"

inet?addr:192.168.120.204??Bcast:192.168.120.255??Mask:255.255.255.0

[root@localhost?test]#?ifconfig?eth0|grep?-E?"([0-9]{1,3}\.){3}[0-9]"

inet?addr:192.168.120.204??Bcast:192.168.120.255??Mask:255.255.255.0

[root@localhost?test]#

說(shuō)明:

實(shí)例12:顯示包含ed或者at字符的內(nèi)容行

命令:

cat?test.txt?|grep?-E?"ed|at"

輸出:

[root@localhost?test]#?cat?test.txt?|grep?-E?"peida|com"

peida.cnblogs.com

[root@localhost?test]#?cat?test.txt?|grep?-E?"ed|at"

redhat

Redhat

[root@localhost?test]#

說(shuō)明:

實(shí)例13:顯示當(dāng)前目錄下面以.txt?結(jié)尾的文件中的所有包含每個(gè)字符串至少有7個(gè)連續(xù)小寫(xiě)字符的字符串的行

命令:

grep?'[a-z]\{7\}'?*.txt

輸出:

[root@localhost?test]#?grep?'[a-z]\{7\}'?*.txt

test.txt:hnlinux

test.txt:peida.cnblogs.com

test.txt:linuxmint

[root@localhost?test]#

實(shí)例14:日志文件過(guò)大,不好查看,我們要從中查看自己想要的內(nèi)容,或者得到同一類(lèi)數(shù)據(jù),比如說(shuō)沒(méi)有404日志信息的

命令:

grep?'.'?access1.log|grep?-Ev?'404'??access2.log

grep?'.'?access1.log|grep?-Ev?'(404|/photo/|/css/)'??access2.log

grep?'.'?access1.log|grep?-E?'404'??access2.log

輸出:

[root@localhost?test]#?grep?“.”access1.log|grep?-Ev?“404”??access2.log

說(shuō)明:上面3句命令前面兩句是在當(dāng)前目錄下對(duì)access1.log文件進(jìn)行查找,找到那些不包含404的行,把它們放到access2.log中,后面去掉’v’,即是把有404的行放入access2.log


當(dāng)前題目:linux過(guò)濾中文中命令 linux系統(tǒng)中哪些工具可以對(duì)文本輸出進(jìn)行過(guò)濾
新聞來(lái)源:http://weahome.cn/article/hjddod.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部