grep (global search regular expression(RE) and print out the line,全面搜索正則表達式並把行列印出來)是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹配的行列印出來。
Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的擴展,支持更多的re元字元, fgrep就是fixed grep或fast grep,它們把所有的字母都看作單詞,也就是說,正則表達式中的元字元表示回其自身的字面意義,不再特殊。linux使用GNU版本的grep。它功能更強,可以通過-G、-E、-F命令行選項來使用egrep和fgrep的功能。
grep的詳細使用方法有很厚一本書,此處無法詳細說明,只能列出grep常用用法
[root@www ~]# grep [-acinv] [--color=auto] '搜尋字元串' filename
選項與參數:
-a :將 binary 文件以 text 文件的方式搜尋數據
-c :計算找到 '搜尋字元串' 的次數
-i :忽略大小寫的不同,所以大小寫視為相同
-n :順便輸出行號
-v :反向選擇,亦即顯示出沒有 '搜尋字元串' 內容的那一行!
--color=auto :可以將找到的關鍵詞部分加上顏色的顯示喔!
② Linux 命令 grep (文檔編輯)-想玩轉linux就請一直看下去
Linux 命令大全
Linux grep 命令用於查找文件里符合條件的字元串。
grep 指令用於查找內容包含指定的範本樣式的文件,如果發現某文件的內容符合所指定的範本樣式,預設 grep 指令會把含有範本樣式的那一列顯示出來。若不指定任何文件名稱,或是所給予的文件名為 - ,則 grep 指令會從標准輸入設備讀取數據。
參數 :
Linux 命令大全
1、在當前目錄中,查找後綴有 file 字樣的文件中包含 test 字元串的文件,並列印出該字元串的行。此時,可以使用如下命令:
結果如下所示:
2、以遞歸的方式查找符合條件的文件。例如,查找指定目錄/etc/acpi 及其子目錄(如果存在子目錄的話)下所有文件中包含字元串"update"的文件,並列印出該字元串所在行的內容,使用的命令為:
輸出結果如下:
3、反向查找。前面各個例子是查找並列印出符合條件的行,通過"-v"參數可以列印出不符合條件行的內容。
查找文件名中包含 test 的文件中不包含test 的行,此時,使用的命令為:
結果如下所示:
③ linux中「grep」和「find」的區別是什麼
這是兩個不同的命令,關於grep:
Linux系統中grep命令是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹 配的行列印出來。grep全稱是Global Regular Expression Print,表示全局正則表達式版本,它的使用許可權是所有用戶。
而linux下的find
功能:在目錄結構中搜索文件,並執行指定的操作。此命令提供了相當多的查找條件,功能很強大。
語法:find 起始目錄 尋找條件 操作
說明:find命令從指定的起始目錄開始,遞歸地搜索其各個子目錄,查找滿足尋找條件的文件並對之採取相關的操作。
所以蘆畢簡單點說說,grep是查找匹配條件的行,find是搜索匹配條件的文件。
④ linux下怎樣在一個文件裡面查找一個字元串
1、在終端使用grep命令查找
2、用vim編輯文件查找
一、使用grep命令查找
格式:
grep 「要查找的字元串」 文件名
例子:
grep 「www.tycode.com」 test.txt
文件名可以使用基本正則表達式(BRE),例如, 查找test目錄下的所有文件,包含www.tycode.com字元串的文件以及該字元串在第幾行。
grep -n「www.tycode.com」 /root/zzh/test/*
linux grep命令
Linux系統中grep命令是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹配的行列印數余中出來。grep全稱是GlobalRegularExpressionPrint,表示全局正則表達式版本,它的使用許可權是所有用戶。
grep的工作方式是這樣的,它在一個或多個毀鎮文件中搜索字元串模板。如果模板包括空格,則必須被引用,模板後的所有字元串被看作文件名。搜索的結果被送到標准輸出,不影響原文件內容。
grep可用於shell腳本,因為grep通過返回一個狀態值來說明搜索的狀態,如果模板搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。我們利用這些返回值就可進行一些自動化的文本處理工作。
1.命令格式:
grep[option]patternfile
2.命令功能:
用於過濾/搜索的特定字元。可使用正則表達式能多種命令配合使用,使用上十薯山分靈活。
⑤ linux命令grep
grep搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。
-n 列印行號
grep -n ".*" h.txt 所有列印行號
grep -n "root" h.txt 匹配的內容顯示行號
-v 不包括
-E 表示過濾 多個參數
grep -Ev "sshd|network|crond|sysstat|"
-o:僅列印你需要的東西,默認列印正行
grep -o "hello" h.txt
-i:忽略大小寫
grep -i "hello" h.txt
-c: 用於統計文中出現的次數
--color=auto 過濾欄位添加顏色
\b:作為邊界符,邊界只包含特定字元的行
grep "\boldboy\b" /etc/passwd -->只過濾包含oldboy的行
從多個文件中查找關鍵詞
grep "omc" /etc/passwd /etc/shadow
數據去重:cat log | sort | uniq
⑥ Linux下Grep命令的詳細使用方法
在linux中grep命令是非常有用的,它和管道(|)配合使用,非常強大,用於搜索文本文件.如果想要在幾個文本文件中查找一字元串,可以使用『grep』命令。『grep』在文本中搜索指定的字元串。
假設您正在『/usr/src/linux/Documentation』目錄下搜索帶字元串『magic』的文件:
$ grep magic /usr/src/linux/Documentation/*
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中文件『sysrp.txt』包含該字元串,討論的是 SysRQ 的功能。
默認情況下,『grep』只搜索當前目錄。如果此目錄下有許多子目錄,『grep』會以如下形式列出:
grep: sound: Is a directory
這可能會使『grep』的輸出難於閱讀。這里有兩種解決的辦法:
明確要求搜索子目錄:grep -r
或忽略子目錄:grep -d skip
當然,如果預料到有許多輸出,您可以通過 管道 將其轉到『less』上閱讀:
$ grep magic /usr/指汪src/linux/Documentation/* | less
這樣,您就可以更方便地閱讀。
有一點要注意,您必需提供一個文件過濾方式(搜索全部文件的話用 *)。如果您忘了,『grep』會一直等著,直到該程序被中斷。如果您遇到了這樣的情況,按
下面是一些有意思的命令行參數:
grep -i pattern files :不區分大小寫地搜索。默認情況區分大小寫,
grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -w pattern files :只匹配整個單詞,而不是字元串的一部分(如匹配『magic』,而不是『magical』),
grep -C number pattern files :匹配的上下文分別顯示[number]行,
grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。
這里還有些用於搜索的特殊符號:
\< 和 \> 分別標注單詞的開始與結尾。
例如:
grep man * 會匹配 『Batman』、『manic』、『man』等,
grep '\
'^':指匹配的字元串在行首,
'$':指匹配的字元串在行尾,
如果您不習慣命令行參數,可以試試圖形界雹逗伏面的『grep』,如 reXgrep 。這個軟體提供 AND、OR、NOT 等語法,還有漂亮的按鈕 :-) 。如果您只是需要更清楚的輸出,不妨試試 fungrep 。
⑦ Linux三劍客之grep
說起Linux操作系統中的 grep 命令,或許沒有人會不知道。在我看來, grep 命令是Linux操作系統上最強大的工具之一,正如你無時無刻不在使用它。無論是從文件中找到匹配的行,又或者是從終端輸出中獲取指定信息,都離不開對 grep 的使用。
了解一個工具的使用,還是先看這個工具的man手冊會告訴我們什麼。
手冊中提到, grep 工具還有兩個孿生兄弟,分別是 egrep 和 fgrep 。其中, egrep 相當於 grep -E 的用法,使用的是擴展形式的正則表達式; fgrep 相當於 grep -F 的用法,根據固定模式進行內容匹配。
對於任何的Linux操作系統,你可以很輕松的找到 /etc/passwd 文件,以下的多數演示將會以該文件進行演示。以下為用戶的部分信息
grep 命令的格式相對比較簡單。完整的命令格式如 grep [OPTIONS] PATTERN [FILE...] ,其中 [OPTIONS] 選項提供了眾多的參數,如下
如果需要找到包含 root 用戶和 adm 用戶的行,可以通過 grep -E "root|adm" /etc/passwd 來查找所有滿足的行
了解 grep 的常用參數可以在工作中解決絕大部份的問題,但在一些情況下,需要對過濾出的內容按照某種規則進行精確匹配,還需要配合正則使用。以下介紹了幾種常用的正則語法
⑧ 4-18 Linux中搜索文件的內容 --- grep
1、grep:用於查找文件里符合條件的字元串(內容)。豐富的參數用於對搜索過程的補充。命令模式十分靈活,可以是變數、字元串、正則表達式。
2、linux 支持 grep、egrep 和 fgrep。grep 和 egrep 都支持正則表達式,只不過 egrep 支持的是擴展正則表達式。fgrep 不支持正則表達式,只支持普通字元串的過濾。
3、grep 加上相應的參數可以實現 egrep 和 fgrep 的功能。所以,也可以用 grep 加上對應的參數來執行 egrep 和 fgrep。
4、通過 man grep 查看說明。
5、grep 命令的基本操作:
②、grep 根據條件過濾文件內容。
三、grep 命令的常用參數。
①、--color=auto:對匹配的字元串用高光顯示。
②、-v:排除過濾條件的行,也就是顯示排除條件以外的內容。
③、-i:忽略大小寫。
④、-n:顯示匹配的行號,列出內容的同時也列出行號。
⑤、-c:統計匹配的行數,只列出共多少行符合過略條件,不列出內容。
⑥、-o:僅顯示匹配的字元串,只顯示文本中含過濾條件的字元串。
⑦、-q:靜默模式,不輸出任何信息。用於返回值判斷,不考慮輸出內容。
⑧、-A:(after),顯示包含當前字元串的後多少行。
⑨、-B:(before),顯示包含當前字元串的前多少行。
⑩、-C:(context),顯示包含當前字元串的前後多少行。
⑩-①、-e:or,或。用於多個參數間的邏輯 或 判斷。
⑩-②、-w:精確匹配,匹配整個單詞。
⑩-③、-f:把過濾條件放到文件中,通過讀取文件的過濾條件進行過濾。
⑩-④、-E:使用 egrep。(支持擴展正則表達式)
⑩-⑤、-F:使用 fgrep(不支持正則表達式)。
②、-v:排除過濾條件的行,也就是顯示排除條件以外的內容。
③、-i:忽略大小寫。
④、-n:顯示匹配的行號,列出內容的同時也列出行號。
⑤、-c:統計匹配的行數,只列出共多少行符合過略條件,不列出內容。
⑥、-o:僅顯示匹配的字元串,只顯示文本中含過濾條件的字元串。
⑦、-q:靜默模式,文本中包不包含過濾條件的字元串都不輸出任何信息。用於返回值判斷,命令執行成功返回 0,失敗返回非 0。
⑧、-A:(after),顯示包含當前字元串的後多少行。
⑨、-B:(before),顯示包含當前字元串的前多少行。
⑩、-C:(context),顯示包含當前字元串的前後多少行。
⑩-①、-e:or,或。用於多個參數間的邏輯 或 判斷。
⑩-②、-w:精確匹配,匹配整個單詞。
⑩-③、-f:把過濾條件放到文件中,通過讀取文件的過濾條件進行過濾。