国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PowerShell > 正文

PowerShell實(shí)現(xiàn)在多個文件中檢索關(guān)鍵字功能

2020-10-29 20:59:38
字體:
供稿:網(wǎng)友

這幾天在看Powershell,感覺挺強(qiáng)大的,一個小任務(wù),是用powershell實(shí)現(xiàn)多個文件中檢索萬行記錄的腳本。剛開始想用用Get-Content 結(jié)合Where-Object來實(shí)現(xiàn),發(fā)現(xiàn)檢索的結(jié)果太慢,而且檢索的條目顯示出來后不知道來自哪個文件,這個雖然也容易實(shí)現(xiàn),但是經(jīng)過對多種方法的探索,我發(fā)現(xiàn)竟然一條強(qiáng)大的命令竟然可以實(shí)現(xiàn)所有這些需求,而且超快的。

一般用于IIS日志分析,由于主要是介紹這個PS命令的,IIS日志是從服務(wù)器端抓取的,這里僅就是測試用的一半數(shù)據(jù)。

首先進(jìn)入到相應(yīng)目錄,查看當(dāng)前目錄下的文件,其中四個log文件是用來測試的。如下:

然后就用下面這條命令實(shí)現(xiàn)那個強(qiáng)大的功能:

比如要搜索關(guān)鍵字write,則輸入write回車之后,搜索到的結(jié)果如下(僅截取部分,這里由于隱私,日志文件是俺造的,只是數(shù)據(jù)量比較大,內(nèi)容純屬虛構(gòu)~~):

可以將這條語句賦給一個臨時(shí)變量,來查看一下在這瞬間查出了多少數(shù)據(jù):

其實(shí)也不多,4個日志文件中瞬間查出了500條數(shù)據(jù),其實(shí)這個看不出來,因?yàn)槲以斓臄?shù)據(jù)量還不夠大。。。

下面對這條強(qiáng)大的命令簡單解釋下:

整體其實(shí)就是使用了Select-String這個命令,具體用法參考:

http://technet.microsoft.com/zh-cn/library/dd315403.aspx

Get-ChildItem是得到當(dāng)前面目錄下的所有項(xiàng),然后通過管道| 輸入給?(就是Where-Object的別名)來篩選,及篩選當(dāng)前目錄下的log文件,$_代表當(dāng)前對象,即前面查出的結(jié)果,-like使用了模式匹配,$(Read-Host)是從控制臺讀入,類似C#中的ReadLine()(相應(yīng)的標(biāo)準(zhǔn)輸出是Write-Host),即當(dāng)用戶輸入一個關(guān)鍵字后,命令會從后向前的執(zhí)行。

由于是剛?cè)腴T,如有出錯,大神們多多指教。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 泰兴市| 淳安县| 友谊县| 晋中市| 顺义区| 中宁县| 鄂伦春自治旗| 收藏| 武川县| 巨鹿县| 寿阳县| 台前县| 马边| 盐池县| 麻江县| 浏阳市| 伊吾县| 临洮县| 台湾省| 且末县| 岢岚县| 呼图壁县| 商都县| 蛟河市| 和田市| 台州市| 永川市| 桃源县| 孟村| 托克逊县| 柳河县| 辽中县| 手游| 越西县| 义马市| 奉新县| 本溪| 万安县| 历史| 乌拉特中旗| 博爱县|