grep 搜尋目錄中的檔案

2021-06-18 01:35:46 字數 3841 閱讀 8149

[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 ...