匹配行linux中grep命令的使用
最近個(gè)人幾篇文章介紹了改匹配行的文章. 關(guān)聯(lián)文章的地址
????linux中g(shù)rep命令的用使
????grep (global search regular expression(RE) and print out the line,全面搜索正則抒發(fā)式并把行印打出來(lái))是一種壯大的文本搜索具工,它能用使正則抒發(fā)式搜索文本,并把匹配的行印打出來(lái)。Unix的grep族家包含grep、egrep和fgrep。
?
grep命令是一種壯大的文本搜索具工,它能用使正則抒發(fā)式搜索文本,并把匹 配的行印打出來(lái)。grep全稱是Global Regular Expression Print,示表全局正則抒發(fā)式版本,它的用使限權(quán)是全部用戶。ps -ef | grep httpd? :檢查httpd進(jìn)程否是存在
????ps -aux |awk '$2~/32651/'濾過(guò)可以用ps -aux |awk '$2!~/32651/' grep 2567會(huì)示顯涌現(xiàn)2567這個(gè)字符串的全部行 ;? | 這是一個(gè)管道,把輸出的結(jié)果作當(dāng)輸入送給下一個(gè)命令。
????awk和sed比grep壯大多了,在講unix的書上grep一般是略帶提的,但awk和sed就會(huì)著重講。
????找查etc錄目下含有字符串“wl0505”的件文:find /etc? -name "*" |xargs grep "wl0505" > ~/thefile
????grep -rn wl0505 /etc/*
????find / -name "*.*" | xargs grep "wl0505" >>/home/filename*.*是件文名和擴(kuò)展名,>>是把結(jié)果重定向到面后徑路的件文中去,不在終端上示顯了。
????"*" 示表匹配帶*這個(gè)字符的行* 示表 找出帶有*的件文 并印打行 find ./ -maxdepth 1 | grep "*"find ./ -maxdepth 1 | grep \*這兩個(gè)命令才是等價(jià)的 對(duì)于 grep來(lái)講 他只受接正則抒發(fā)式匹配 * ? 這些字符須要加轉(zhuǎn)義符 \
????linux下的find與grep命令的功能不同。find? 命令用于從錄目樹(shù)中找查與搜索條件匹配的件文;grep 命令用于找查輸入流中包含模板文本的行。find 命令常結(jié)合grep命令用使, 以對(duì)搜索結(jié)果做進(jìn)一步的篩選
????匹配錄目/cpl下全部(遞歸找查)以'#'掃尾的件文:
????OCS101:~/cpl # grep -r '^#' .
./fk.c:#include<stdio.h>
./fk.c:#include<math.h>
./flower2.c:#include <stdio.h>
./flower2.c:#include <time.h>
./recursive_flower.c:#include<stdio.h>
./recursive_flower.c:#include <stdlib.h>
./recursive_flower.c:#include <time.h>
./recursive_flower.c:#define m 8
./flower.c:#include <stdio.h>
./flower.c:#include <stdlib.h>
./flower.c:#include <time.h>
./flower.c:#define N 1e8
????匹配錄目/cpl下全部(遞歸找查)以'}'尾結(jié)的件文:
????OCS101:~/cpl # grep -r '^}' .
./fk.c:}
./fk.c:}
./fk.c:}
./Narcissus.java:}
./flower2.c:}
./flower2.c:}
./flower2.c:}
./recursive_flower.c:}
./recursive_flower.c:}
./recursive_flower.c:}
./recursive_flower.c:}
./flower.c:}
./flower.c:}
./flower.c:}
./flower.c:}
./flower.c:}
?
每日一道理能夠破碎的人,必定真正活過(guò)。林黛玉的破碎,在于她有刻骨銘心的愛(ài)情;三毛的破碎,源于她歷經(jīng)滄桑后一剎那的明徹與超脫;凡高的破碎,是太陽(yáng)用黃金的刀子讓他在光明中不斷劇痛,貝多芬的破碎,則是靈性至極的黑白鍵撞擊生命的悲壯樂(lè)章。如果說(shuō)那些平凡者的破碎泄漏的是人性最純最美的光點(diǎn),那么這些優(yōu)秀的靈魂的破碎則如銀色的梨花開(kāi)滿了我們頭頂?shù)奶炜铡?br />
????
抒發(fā)符集
^
定錨行的開(kāi)始 如:'^grep'匹配全部以grep掃尾的行。
$
定錨行的束結(jié) 如:'grep$'匹配全部以grep尾結(jié)的行。
.
匹配一個(gè)非換行符的字符如:'gr.p'匹配gr后接一個(gè)意任字符,然后是p。
*
匹配零個(gè)或多個(gè)先前字符 如:' *grep' (意注*前有空格)匹配全部零個(gè)或多個(gè)空格后緊跟grep的行,須要用egrep 或者grep帶上 -E 選項(xiàng)。 .*一升引代表意任字符。
[]
匹配一個(gè)指定范圍內(nèi)的字符,如'[Gg]rep'匹配Grep和grep。
[^]
匹配一個(gè)不在指定范圍內(nèi)的字符,如:'[^A-FH-Z]rep'匹配不包含A-F和H-Z的一個(gè)字母掃尾,緊跟rep的行。
\(..\)
記標(biāo)匹配字符,如'\(love\)',love被記標(biāo)為1。
\<
定錨單詞的開(kāi)始,如:'\<grep'匹配包含以grep掃尾的單詞的行。
\>
定錨單詞的束結(jié),如'grep\>'匹配包含以grep尾結(jié)的單詞的行。
x\{m\}
重復(fù)字符x,m次,如:'o\{5\}'匹配包含5個(gè)o的行。
x\{m,\}
重復(fù)字符x,最少m次,如:'o\{5,\}'匹配最少有5個(gè)o的行。
x\{m,n\}
重復(fù)字符x,最少m次,不多于n次,如:'o\{5,10\}'匹配5--10個(gè)o的行。
\w
匹配文字和數(shù)字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零個(gè)或多個(gè)文字或數(shù)字字符,然后是p。
\W
\w的反置式形,匹配一個(gè)或多個(gè)非單詞字符,如點(diǎn)號(hào)句號(hào)等。
\b
單詞鎖定符,如: '\bgrep\b'只匹配grep。[1]用于egrep和 grep -E的元字符擴(kuò)展集
+
匹配一個(gè)或多個(gè)先前的字符。如:'[a-z]+able',匹配一個(gè)或多個(gè)小寫字母后跟able的串,如loveable,enable,disable等。
?
匹配零個(gè)或一個(gè)先前的字符。如:'gr?p'匹配gr后跟一個(gè)或沒(méi)有字符,然后是p的行。
a|b|c
匹配a或b或c。如:grep|sed匹配grep或sed
()
組分號(hào)符,如:love(able|rs)ov+匹配loveable或lovers,匹配一個(gè)或多個(gè)ov。
x{m},x{m,},x{m,n}
作用同x\{m\},x\{m,\},x\{m,n\}
POSIX字符類
為了在不同國(guó)度的字符編碼中持保一至,POSIX(The Portable Operating System Interface)增加了特別的字符類,如[:alnum:]是A-Za-z0-9的另一個(gè)寫法。要把它們放到[]號(hào)內(nèi)才能成為正則抒發(fā)式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支撐POSIX的字符類。
[:alnum:]
文字?jǐn)?shù)字字符
[:alpha:]
文字字符
[:digit:]
數(shù)字字符
[:graph:]
非空字符(非空格、控制字符)
[:lower:]
小寫字符
[:cntrl:]
控制字符
[:print:]
非空字符(包含空格)
[:punct:]
標(biāo)點(diǎn)號(hào)符
[:space:]
全部空白字符(新行,空格,制表符)
[:upper:]
大寫字符
[:xdigit:]
十六進(jìn)制數(shù)字(0-9,a-f,A-F)
命令選項(xiàng)
-?
同時(shí)示顯匹配行上下的?行,如:grep -2 pattern filename同時(shí)示顯匹配行的上下2行。
-a, --text
等價(jià)于匹配text,用于(Binary file (standard input) matches)報(bào)錯(cuò)
-b,--byte-offset
印打匹配行面前印打該行在所的塊碼號(hào)。
-c,--count
只印打匹配的行數(shù),不示顯匹配的內(nèi)容。
-f File,--file=File
從件文中取提模板。空件文中包含0個(gè)模板,所以什么都不匹配。
-h,--no-filename
當(dāng)搜索多個(gè)件文時(shí),不示顯匹配件文名前綴。
-i,--ignore-case
略忽大小寫差異。
-q,--quiet
取消示顯,只回返退出狀態(tài)。0則示表找到了匹配的行。
-l,--files-with-matches
印打匹配模板的件文清單。
-L,--files-without-match
印打不匹配模板的件文清單。
-n,--line-number
在匹配的行面前印打行號(hào)。
-s,--silent
不示顯關(guān)于不存在或者法無(wú)取讀件文的錯(cuò)誤信息。
-v,--revert-match
反檢索,只示顯不匹配的行。
-w,--word-regexp
如果被\<和\>引用,就把抒發(fā)式做為一個(gè)單詞搜索。
-R, -r, --recursive
遞歸的取讀錄目下的全部件文,包含子錄目。 比如grep -R 'pattern' test會(huì)在 test 及其子錄目下的全部件文中,匹配 pattern。
-V,--version
示顯軟件版本信息。
實(shí)例
要用好grep這個(gè)具工,其實(shí)就是要寫好正則抒發(fā)式,所以這里不對(duì)grep的全部功能停止實(shí)例解講,只列幾個(gè)例子,解講一個(gè)正則抒發(fā)式的寫法。
$ ls -l | grep '^a'
通過(guò)管道濾過(guò)ls -l輸出的內(nèi)容,只示顯以a掃尾的行。
$ grep 'test' d*
示顯全部以d掃尾的件文中包含test的行。
$ grep 'test' aa bb cc
示顯在aa,bb,cc件文中匹配test的行。
$ grep '[a-z]\{5\}' aa
示顯全部包含每一個(gè)字符串有5個(gè)續(xù)連小寫字符的字符串的行。
$ grep 'w\(es\)t.*\1' aa
如果west被匹配,則es就被存儲(chǔ)到內(nèi)存中,并記標(biāo)為1,然后搜索意任個(gè)字符(.*),這些字符面后緊跟著另外一個(gè)es(\1),找到就示顯該行。如果用egrep或grep -E,就不必"\"號(hào)停止轉(zhuǎn)義,直接寫成'w(es)t.*\1'以可就了。
意注
在某些呆板上,要用使-E參數(shù)才能夠停止邏輯匹配(詳見(jiàn)下)
grep "a|b" (匹配包含字符款式為"a|b"的行)
grep -E "a|b" (匹配包含字符款式為"a"或"b"的行)
man grep面里關(guān)于-E參數(shù)的說(shuō)明是
-E
Treats each pattern specified as an extended regular expression (ERE). A NULL value for the ERE matches every
line.
Note: The grep command with the -E flag is the same as the egrep command, except that error and usage messages
are different and the -s flag functions differently.
拓展命令
egrep 命令,搜索件文得獲模式。
egrep 命令會(huì)在輸入件文(缺省值為標(biāo)準(zhǔn)輸入)中搜索與用 Pattern 參數(shù)指定的模式相匹配的行。這些模式是整完的正則抒發(fā)式就像在 ed 命令中的那樣(除了 \ (反斜杠)和 \\ (雙反斜杠))。以下規(guī)矩也應(yīng)用于 egrep 命令:
* 一個(gè)正則抒發(fā)式面后帶一個(gè) + (加號(hào))會(huì)匹配一個(gè)或多個(gè)的正則抒發(fā)式。
* 一個(gè)正則抒發(fā)式面后帶一個(gè) ? (問(wèn)號(hào))會(huì)匹配零個(gè)或一個(gè)該正則抒發(fā)式。
* 由 | (豎線)或者換行符隔開(kāi)的多個(gè)正則抒發(fā)式會(huì)匹配與任何一個(gè)正則抒發(fā)式所匹配的字符串。
* 一個(gè)正則抒發(fā)式可以被包含在“()”(括弧)中停止組分。
換行符將不會(huì)被正則抒發(fā)式匹配。
運(yùn)算符的優(yōu)先順序是 [, ], *, ?, +, 合并, | 和換行符。
意注: egrep 命令與 grep 命令帶 -E 標(biāo)志是一樣的,除了錯(cuò)誤消息和用使消息不同以及 -s 標(biāo)志的功能不同之外。
egrep 命令會(huì)示顯包含該匹配行的件文,如果您指定了多于一個(gè) File 參數(shù)的話。
對(duì) shell 有特別含義的字符($, *, [, |, ^, (, ), \ ) 涌現(xiàn)在 Pattern 參數(shù)中時(shí)必須帶雙引號(hào)。如果 Pattern 參數(shù)不是簡(jiǎn)單字符串,通常必須用單引號(hào)將整個(gè)模式括起來(lái)。在抒發(fā)式中比如 [a-z],減號(hào)示表通過(guò)當(dāng)前整理序列。整理序列可以定義等價(jià)的類以供在字符范圍中用使。它用使了快速確定性的算法,有時(shí)須要外部空間。[2]fgrep命令, 為件文搜索文字字符串。
fgrep命令搜索 File 參數(shù)指定的輸入件文(缺省為標(biāo)準(zhǔn)輸入)中的匹配模式的行。fgrep命令特別搜索 Pattern 參數(shù),它們是固定的字符串。如果在 File 參數(shù)中指定一個(gè)以上的件文fgrep命令將示顯包含匹配行的件文。
fgrep命令于 grep 和 egrep 命令不同,因?yàn)樗阉髯址皇撬阉髌ヅ涫惆l(fā)式的模式。fgrep命令用使快速的壓縮算法。$, *, [, |, (, ) 和 \ 等字符串被fgrep命令按字面意思解釋。這些字符并不解釋為正則抒發(fā)式,但它們?cè)?grep 和 egrep 命令中解釋為正則抒發(fā)式。
因?yàn)檫@些字符對(duì)于 shell 有特定的含義,整完的字符串應(yīng)該加上單引號(hào)(‘ ... ’)。
如果沒(méi)有指定件文,fgrep命令假定標(biāo)準(zhǔn)輸入。一般,找到的每行都復(fù)制到標(biāo)準(zhǔn)輸出中去。如果不止一個(gè)輸入件文,則在找到的每行前印打件文名。
文章結(jié)束給大家分享下程序員的一些笑話語(yǔ)錄: 自行車
一個(gè)程序員騎著一個(gè)很漂亮的自行車到了公司,另一個(gè)程序員看到了他,問(wèn) 到,“你是從哪搞到的這么漂亮的車的?”
騎車的那個(gè)程序員說(shuō), “我剛從那邊過(guò)來(lái), 有一個(gè)漂亮的姑娘騎著這個(gè)車過(guò)來(lái), 并停在我跟前,把衣服全脫了,然后對(duì)我說(shuō),‘你想要什么都可以’”。
另一個(gè)程序員馬上說(shuō)到, “你絕對(duì)做了一個(gè)正確的選擇, 因?yàn)槟枪媚锏囊路?并不一定穿得了”。
轉(zhuǎn)載于:https://www.cnblogs.com/xinyuyuanm/archive/2013/04/29/3050580.html
總結(jié)
以上是生活随笔為你收集整理的匹配行linux中grep命令的使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 火焰纹章继晓之女神后一部是什么(火焰的本
- 下一篇: linux查看最近修改过的文件