[plain]view plain
copy
grep -fnr class ./
以上命令的意思是:在當前目錄下的所有檔案中搜尋「class」,並顯示檔名、行號和匹配所在行內容
2.在某目錄下的所有檔案中,按使用正則搜尋
[plain]view plain
copy
grep -pnr "\d" ./
-p 是 perl 正規表示式,經過測試,發現此模式支援的正則最完整,支援正則的完整度由大到小為: -p > -e > -g
建議正則搜尋時就直接使用-p模式,以避免去記憶-e和-g模式不支援的正則列表
3.只搜尋某一類檔案
[plain]view plain
copy
grep -pnr "\d" `find -name "*.txt"`
4.只搜尋某幾類檔案,如下,只搜尋txt和php檔案
[plain]view plain
copy
grep -pnr "\d" `find |grep -p ".(txt|php)$"`
[plain]view plain
copy
grep -pnr "\d" `ls |grep -fv weiba`
-v排除匹配項
6.更強功能的子目錄篩選
[plain]view plain
copy
grep -pnr "\d" `ls |grep -pv '^(weiba|huati)$'`
grep -pnr "\d" `ls |grep -p '^(weiba|huati)$'`
用法: grep [選項]... pattern [file]...
在每個 file 或是標準輸入中查詢 pattern。
預設的 pattern 是乙個基本正規表示式(縮寫為 bre)。
例如: grep -i 'hello world' menu.h main.c
正規表示式選擇與解釋:
-e, --extended-regexp pattern 是乙個可擴充套件的正規表示式(縮寫為 ere)
-f, --fixed-strings pattern 是一組由斷行符分隔的定長字串。
-g, --basic-regexp pattern 是乙個基本正規表示式(縮寫為 bre)
-p, --perl-regexp pattern 是乙個 perl 正規表示式
-e, --regexp=pattern 用 pattern 來進行匹配操作
-f, --file=file 從 file 中取得 pattern
-i, --ignore-case 忽略大小寫
-w, --word-regexp 強制 pattern 僅完全匹配字詞
-x, --line-regexp 強制 pattern 僅完全匹配一行
-z, --null-data 乙個 0 位元組的資料行,但不是空行
雜項:-s, --no-messages 不顯示錯誤資訊
-v, --invert-match 選中不匹配的行
-v, --version 顯示版本資訊並退出
--help 顯示此幫助並退出
--mmap 忽略向後相容性
輸出控制:
-m, --max-count=num num 次匹配後停止
-b, --byte-offset 輸出行的同時列印位元組偏移
-n, --line-number 輸出行的同時列印行號
--line-buffered 每行輸出清空
-h, --with-filename 為每一匹配項列印檔案名
-h, --no-filename 輸出時不顯示檔名字首
--label=label 標準輸入將label 列印為檔名
-o, --only-matching 只顯示一行中匹配pattern 的部分
-q, --quiet, --silent 不顯示所有輸出
--binary-files=type 假定二進位制檔案的type 型別;
type 可以是`binary', `text', 或`without-match'
-a, --text 等同於 --binary-files=text
-i 等同於 --binary-files=without-match
-d, --directories=action 操作目錄的方式;
action 可以是`read', `recurse',或`skip'
-d, --devices=action 操作裝置、先入先出佇列、套接字的方式;
action 可以是`read'或`skip'
-r, -r, --recursive 等同於 --directories=recurse
--include=file_pattern 只查詢匹配file_pattern 的檔案
--exclude=file_pattern 跳過匹配file_pattern 的檔案和目錄
--exclude-from=file 跳過所有除file 以外的檔案
--exclude-dir=pattern 跳過所有匹配pattern 的目錄。
-l, --files-without-match 只列印不匹配files 的檔名
-l, --files-with-matches 只列印匹配files 的檔名
-c, --count 只列印每個file 中的匹配行數目
-t, --initial-tab 行首tabs 分隔(如有必要)
-z, --null 在file 檔案最後列印空字元
檔案控制:
-b, --before-context=num 列印以文字起始的num 行
-a, --after-context=num 列印以文字結尾的num 行
-c, --context=num 列印輸出文字num 行
-num 等同於 --context=num
--color[=when],
--colour[=when] 使用標誌高亮匹配字串;
when 可以是`always', `never'或`auto'
-u, --binary 不要清除行尾的cr 字元(msdos 模式)
-u, --unix-byte-offsets 當cr 字元不存在,報告位元組偏移(msdos 模式)
『egrep』即『grep -e』。『fgrep』即『grep -f』。
直接使用『egrep』或是『fgrep』均已不可行了。
不帶 file 引數,或是 file 為 -,將讀取標準輸入。如果少於兩個 file 引數
就要預設使用 -h 引數。如果選中任意一行,那退出狀態為 0,否則為 1;
如果有錯誤產生,且未指定 -q 引數,那退出狀態為 2。
from:
grep 搜尋目錄中的檔案
plain view plain copy grep fnr class 以上命令的意思是 在當前目錄下的所有檔案中搜尋 class 並顯示檔名 行號和匹配所在行內容 2.在某目錄下的所有檔案中,按使用正則搜尋 plain view plain copy grep pnr d p 是 perl 正規...
Grep 從檔案中搜尋字串
o 只輸出匹配部分 把匹配部分從行中挑出來 h 顯示檔名 h 不顯示檔名 c n 顯示匹配上下文 v 反檢索,顯示不匹配的行 l 輸出匹配的檔案 l 輸出不匹配的檔案 n 顯示行號 i 忽略大小寫 w 匹配整個word x 匹配整行 p perl正則風格 e 擴充套件的 extension 正規表示...
4 3 用grep在檔案中搜尋文字
命令 grep 用途 搜尋文字 用法 grep match pattern filename 1.支援多種匹配格式 e 支援正規表示式,等同egrep yang ubuntu echo this is a line.grep e a z this isa line.yang ubuntu echo ...