91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux grep命令怎么使用

發布時間:2022-02-07 16:58:17 來源:億速云 閱讀:163 作者:iii 欄目:開發技術

這篇文章主要介紹了Linux grep命令怎么使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Linux grep命令怎么使用文章都會有所收獲,下面我們一起來看看吧。

Linux常用命令grep是一種強大的文本搜索工具,它能使用正則表達式搜索文本,并把匹配的行打印出來。用于過濾/搜索的特定字符。可使用正則表達式能配合多種命令使用,使用上十分靈活。

Linux grep命令怎么使用

grep

強大的文本搜索工具

選項

 -a --text  # 不要忽略二進制數據。
 -A    --after-context=   # 除了顯示符合范本樣式的那一行之外,并顯示該行之后的內容。
 -b --byte-offset                           # 在顯示符合范本樣式的那一行之外,并顯示該行之前的內容。
 -B   --before-context=   # 除了顯示符合樣式的那一行之外,并顯示該行之前的內容。
 -c --count    # 計算符合范本樣式的列數。
 -C --context=或- # 除了顯示符合范本樣式的那一列之外,并顯示該列之前后的內容。
 -d --directories=  # 當指定要查找的是目錄而非文件時,必須使用這項參數,否則grep命令將回報信息并停止動作。
 -e --regexp=   # 指定字符串作為查找文件內容的范本樣式。
 -E --extended-regexp             # 將范本樣式為延伸的普通表示法來使用,意味著使用能使用擴展正則表達式。
 -f --file=     # 指定范本文件,其內容有一個或多個范本樣式,讓grep查找符合范本條件的文件內容,格式為每一列的范本樣式。
 -F --fixed-regexp   # 將范本樣式視為固定字符串的列表。
 -G --basic-regexp   # 將范本樣式視為普通的表示法來使用。
 -h --no-filename    # 在顯示符合范本樣式的那一列之前,不標示該列所屬的文件名稱。
 -H --with-filename  # 在顯示符合范本樣式的那一列之前,標示該列的文件名稱。
 -i --ignore-case    # 忽略字符大小寫的差別。
 -l --file-with-matches   # 列出文件內容符合指定的范本樣式的文件名稱。
 -L --files-without-match # 列出文件內容不符合指定的范本樣式的文件名稱。
 -n --line-number         # 在顯示符合范本樣式的那一列之前,標示出該列的編號。
 -P --perl-regexp         # PATTERN 是一個 Perl 正則表達式
 -q --quiet或--silent     # 不顯示任何信息。
 -R/-r  --recursive       # 此參數的效果和指定“-d recurse”參數相同。
 -s --no-messages  # 不顯示錯誤信息。
 -v --revert-match # 反轉查找。
 -V --version      # 顯示版本信息。  
 -w --word-regexp  # 只顯示全字符合的列。
 -x --line-regexp  # 只顯示全列符合的列。
 -y # 此參數效果跟“-i”相同。
 -o # 只輸出文件中匹配到的部分。
 -m  --max-count= # 找到num行結果后停止查找,用來限制匹配行數

規則表達式

 ^    # 錨定行的開始 如:'^grep'匹配所有以grep開頭的行。    
 $    # 錨定行的結束 如:'grep$' 匹配所有以grep結尾的行。
 .    # 匹配一個非換行符的字符 如:'gr.p'匹配gr后接一個任意字符,然后是p。    
 *    # 匹配零個或多個先前字符 如:'*grep'匹配所有一個或多個空格后緊跟grep的行。    
 .*   # 一起用代表任意字符。  
 []   # 匹配一個指定范圍內的字符,如'[Gg]rep'匹配Grep和grep。    
 [^]  # 匹配一個不在指定范圍內的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個字母開頭,緊跟rep的行。    
 \(..\)  # 標記匹配字符,如'\(love\)',love被標記為1。    
 \      # 錨定單詞的結束,如'grep\>'匹配包含以grep結尾的單詞的行。    
 x\{m\}  # 重復字符x,m次,如:'0\{5\}'匹配包含5個o的行。    
 x\{m,\}   # 重復字符x,至少m次,如:'o\{5,\}'匹配至少有5個o的行。    
 x\{m,n\}  # 重復字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10個o的行。  
 \w    # 匹配文字和數字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零個或多個文字或數字字符,然后是p。  
 \W    # \w的反置形式,匹配一個或多個非單詞字符,如點號句號等。  
 \b    # 單詞鎖定符,如: '\bgrep\b'只匹配grep。

grep命令常見用法

在文件中搜索一個單詞,命令會返回一個包含 “match_pattern” 的文本行:

 grep match_pattern file_name
 grep "match_pattern" file_name

在多個文件中查找:

 grep "match_pattern" file_1 file_2 file_3 ...

輸出除之外的所有行  -v  選項:

 grep -v "match_pattern" file_name

標記匹配顏色  –color=auto  選項:

 grep "match_pattern" file_name --color=auto

使用正則表達式  -E  選項:

 grep -E "[1-9]+"
 # 或
 egrep "[1-9]+"

使用正則表達式  -P  選項:

 grep -P "(\d{3}\-){2}\d{4}" file_name

只輸出文件中匹配到的部分  -o  選項:

echo this is a test line. | grep -o -E "[a-z]+\."
line.

echo this is a test line. | egrep -o "[a-z]+\."
line.

統計文件或者文本中包含匹配字符串的行數  -c  選項:

grep -c "text" file_name

輸出包含匹配字符串的行數  -n  選項:

grep "text" -n file_name
# 或
cat file_name | grep "text" -n

#多個文件
grep "text" -n file_1 file_2

打印樣式匹配所位于的字符或字節偏移:

echo gun is not unix | grep -b -o "not"
7:not
#一行中字符串的字符便宜是從該行的第一個字符開始計算,起始值為0。選項  **-b -o**  一般總是配合使用。

搜索多個文件并查找匹配文本在哪些文件中:

grep -l "text" file1 file2 file3...

grep遞歸搜索文件

在多級目錄中對文本進行遞歸搜索:

grep "text" . -r -n
# .表示當前目錄。

忽略匹配樣式中的字符大小寫:

echo "hello world" | grep -i "HELLO"
# hello

選項  -e  制動多個匹配樣式:

echo this is a text line | grep -e "is" -e "line" -o
is
line

#也可以使用 **-f** 選項來匹配多個樣式,在樣式文件中逐行寫出需要匹配的字符。
cat patfile
aaa
bbb

echo aaa bbb ccc ddd eee | grep -f patfile -o

在grep搜索結果中包括或者排除指定文件:

# 只在目錄中所有的.php和.html文件中遞歸搜索字符"main()"
grep "main()" . -r --include *.{php,html}

# 在搜索結果中排除所有README文件
grep "main()" . -r --exclude "README"

# 在搜索結果中排除filelist文件列表里的文件
grep "main()" . -r --exclude-from filelist

使用0值字節后綴的grep與xargs:

# 測試文件:
echo "aaa" > file1
echo "bbb" > file2
echo "aaa" > file3

grep "aaa" file* -lZ | xargs -0 rm

# 執行后會刪除file1和file3,grep輸出用-Z選項來指定以0值字節作為終結符文件名(\0),xargs -0 讀取輸入并用0值字節終結符分隔文件名,然后刪除匹配文件,-Z通常和-l結合使用。

grep靜默輸出:

grep -q "test" filename
# 不會輸出任何信息,如果命令運行成功返回0,失敗則返回非0值。一般用于條件測試。

打印出匹配文本之前或者之后的行:

# 顯示匹配某個結果之后的3行,使用 -A 選項:
seq 10 | grep "5" -A 3
5
6
7
8

# 顯示匹配某個結果之前的3行,使用 -B 選項:
seq 10 | grep "5" -B 3
2
3
4
5

# 顯示匹配某個結果的前三行和后三行,使用 -C 選項:
seq 10 | grep "5" -C 3
2
3
4
5
6
7
8

# 如果匹配結果有多個,會用“--”作為各匹配結果之間的分隔符:
echo -e "a\nb\nc\na\nb\nc" | grep a -A 1
a
b
--
a
b

關于“Linux grep命令怎么使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Linux grep命令怎么使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

信丰县| 兰州市| 寿阳县| 通城县| 深泽县| 宣化县| 商都县| 乾安县| 太和县| 舟曲县| 凤山县| 湖口县| 沙雅县| 宾阳县| 兴隆县| 恩平市| 伊宁县| 万载县| 九寨沟县| 安仁县| 平山县| 枞阳县| 府谷县| 连江县| 舞阳县| 库车县| 探索| 松原市| 涿鹿县| 巴彦淖尔市| 平原县| 确山县| 庐江县| 东乌珠穆沁旗| 清丰县| 龙海市| 神池县| 九龙城区| 陆丰市| 禹城市| 东城区|