HOME 首頁(yè)
SERVICE 服務(wù)產(chǎn)品
XINMEITI 新媒體代運(yùn)營(yíng)
CASE 服務(wù)案例
NEWS 熱點(diǎn)資訊
ABOUT 關(guān)于我們
CONTACT 聯(lián)系我們
創(chuàng)意嶺
讓品牌有溫度、有情感
專注品牌策劃15年

    grep參數(shù)列表過(guò)長(zhǎng)(grep 參數(shù))

    發(fā)布時(shí)間:2023-04-14 09:36:51     稿源: 創(chuàng)意嶺    閱讀: 96        

    大家好!今天讓創(chuàng)意嶺的小編來(lái)大家介紹下關(guān)于grep參數(shù)列表過(guò)長(zhǎng)的問(wèn)題,以下是小編對(duì)此問(wèn)題的歸納整理,讓我們一起來(lái)看看吧。

    開(kāi)始之前先推薦一個(gè)非常厲害的Ai人工智能工具,一鍵生成原創(chuàng)文章、方案、文案、工作計(jì)劃、工作報(bào)告、論文、代碼、作文、做題和對(duì)話答疑等等

    只需要輸入關(guān)鍵詞,就能返回你想要的內(nèi)容,越精準(zhǔn),寫(xiě)出的就越詳細(xì),有微信小程序端、在線網(wǎng)頁(yè)版、PC客戶端

    官網(wǎng):https://ai.de1919.com

    創(chuàng)意嶺作為行業(yè)內(nèi)優(yōu)秀的企業(yè),服務(wù)客戶遍布全球各地,如需了解SEO相關(guān)業(yè)務(wù)請(qǐng)撥打電話175-8598-2043,或添加微信:1454722008

    本文目錄:

    grep參數(shù)列表過(guò)長(zhǎng)(grep 參數(shù))

    一、grep命令詳解

    linux grep命令:

    <p fc05="" fc11="" nbw-blog="" ztag="" js-fs2"="">

    1、作用

    Linux系統(tǒng)中g(shù)rep命令是一種強(qiáng)大的文本搜索工具,它能使用正則表達(dá)式搜索文本,并把匹 配的行打印出來(lái)。grep全稱是Global Regular Expression print,表示全局正則表達(dá)式版本,它的使用權(quán)限是所有用戶。

    2、格式

    grep [options]

    3、主要參數(shù)

    [options]主要參數(shù):

    -c:只輸出匹配行的計(jì)數(shù)。

    -I:不區(qū)分大 小寫(xiě)(只適用于單字符)。

    -h(huán):查詢多文件時(shí)不顯示文件名。

    -l:查詢多文件時(shí)只輸出包含匹配字符的文件名。

    -n:顯示匹配行及 行號(hào)。

    -s:不顯示不存在或無(wú)匹配文本的錯(cuò)誤信息。

    -v:顯示不包含匹配文本的所有行。

    pattern正則表達(dá)式主要參數(shù):

    : 忽略正則表達(dá)式中特殊字符的原有含義。

    ^:匹配正則表達(dá)式的開(kāi)始行。

    $: 匹配正則表達(dá)式的結(jié)束行。

    <:從匹配正則表達(dá) 式的行開(kāi)始。

    >:到匹配正則表達(dá)式的行結(jié)束。

    [ ]:?jiǎn)蝹€(gè)字符,如[A]即A符合要求 。

    [ - ]:范圍,如[A-Z],即A、B、C一直到Z都符合要求 。

    。:所有的單個(gè)字符。

    * :有字符,長(zhǎng)度可以為0。

    4.grep命令使用簡(jiǎn)單實(shí)例

    $ grep ‘test’ d*

    顯示所有以d開(kāi)頭的文件中包含 test的行。

    $ grep ‘test’ aa bb cc

    顯示在aa,bb,cc文件中匹配test的行。

    $ grep ‘[a-z]{5}’ aa

    顯示所有包含每個(gè)字符串至少有5個(gè)連續(xù)小寫(xiě)字符的字符串的行。

    $ grep ‘w(es)t.*1′ aa

    grep參數(shù)列表過(guò)長(zhǎng)(grep 參數(shù))

    擴(kuò)展資料:

    egrep 命令,搜索文件獲得模式。egrep 命令會(huì)在輸入文件(缺省值為標(biāo)準(zhǔn)輸入)中搜索與Pattern 參數(shù)指定的模式相匹配的行。這些模式是完整的正則表達(dá)式就像在 ed 命令中的那樣(除了 (反斜杠)和 \ (雙反斜杠))。下列規(guī)則也應(yīng)用于 egrep 命令:

    一個(gè)正則表達(dá)式后面帶一個(gè) + (加號(hào))會(huì)匹配一個(gè)或多個(gè)的正則表達(dá)式,一個(gè)正則表達(dá)式后面帶一個(gè) ? (問(wèn)號(hào))會(huì)匹配零個(gè)或一個(gè)該正則表達(dá)式,由 | (豎線)或者換行符隔開(kāi)的多個(gè)正則表達(dá)式會(huì)匹配與任何一個(gè)正則表達(dá)式所匹配的字符串。

    一個(gè)正則表達(dá)式可以被包括在“()”(括弧)中進(jìn)行分組,換行符將不會(huì)被正則表達(dá)式匹配,運(yùn)算符的優(yōu)先順序是 [, ], *, ?, +, 合并, | 和換行符。

    注意: egrep 命令與 grep 命令帶 -E 標(biāo)志是一樣的,除了錯(cuò)誤消息和使用消息不同以及 -s 標(biāo)志的功能不同之外,egrep 命令會(huì)顯示包含該匹配行的文件,如果指定了多于一個(gè) File 參數(shù)的話。

    參考資料:百度百科—GREP

    參考資料:百度百科—linux命令

    二、Linux常用指令---grep(搜索過(guò)濾)(轉(zhuǎn))

    Linux常用指令---grep(搜索過(guò)濾) (轉(zhuǎn))

    Linux系統(tǒng)中g(shù)rep命令是一種強(qiáng)大的文本搜索工具,它能使用正則表達(dá)式搜索文本,并把匹 配的行打印出來(lái)。grep全稱是Global Regular Expression Print,表示全局正則表達(dá)式版本,它的使用權(quán)限是所有用戶。

    grep的工作方式是這樣的,它在一個(gè)或多個(gè)文件中搜索字符串模板。如果模板包括空格,則必須被引用,模板后的所有字符串被看作文件名。搜索的結(jié)果被送到標(biāo)準(zhǔn)輸出,不影響原文件內(nèi)容。

    grep可用于shell腳本,因?yàn)間rep通過(guò)返回一個(gè)狀態(tài)值來(lái)說(shuō)明搜索的狀態(tài),如果模板搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。我們利用這些返回值就可進(jìn)行一些自動(dòng)化的文本處理工作。

    1.命令格式:

    grep [option] pattern file

    2.命令功能:

    用于過(guò)濾/搜索的特定字符??墒褂谜齽t表達(dá)式能多種命令配合使用,使用上十分靈活。

    3.命令參數(shù):

    -a   --text   #不要忽略二進(jìn)制的數(shù)據(jù)。   

    -A<顯示行數(shù)>   --after-context=<顯示行數(shù)>   #除了顯示符合范本樣式的那一列之外,并顯示該行之后的內(nèi)容。   

    -b   --byte-offset   #在顯示符合樣式的那一行之前,標(biāo)示出該行第一個(gè)字符的編號(hào)。   

    -B<顯示行數(shù)>   --before-context=<顯示行數(shù)>   #除了顯示符合樣式的那一行之外,并顯示該行之前的內(nèi)容。   

    -c    --count   #計(jì)算符合樣式的列數(shù)。   

    -C<顯示行數(shù)>    --context=<顯示行數(shù)>或-<顯示行數(shù)>   #除了顯示符合樣式的那一行之外,并顯示該行之前后的內(nèi)容。   

    -d <動(dòng)作>      --directories=<動(dòng)作>   #當(dāng)指定要查找的是目錄而非文件時(shí),必須使用這項(xiàng)參數(shù),否則grep指令將回報(bào)信息并停止動(dòng)作。   

    -e<范本樣式>  --regexp=<范本樣式>   #指定字符串做為查找文件內(nèi)容的樣式。   

    -E      --extended-regexp   #將樣式為延伸的普通表示法來(lái)使用。   

    -f<規(guī)則文件>  --file=<規(guī)則文件>   #指定規(guī)則文件,其內(nèi)容含有一個(gè)或多個(gè)規(guī)則樣式,讓grep查找符合規(guī)則條件的文件內(nèi)容,格式為每行一個(gè)規(guī)則樣式。   

    -F   --fixed-regexp   #將樣式視為固定字符串的列表。   

    -G   --basic-regexp   #將樣式視為普通的表示法來(lái)使用。   

    -h   --no-filename   #在顯示符合樣式的那一行之前,不標(biāo)示該行所屬的文件名稱。   

    -H   --with-filename   #在顯示符合樣式的那一行之前,表示該行所屬的文件名稱。   

    -i    --ignore-case   #忽略字符大小寫(xiě)的差別。   

    -l    --file-with-matches   #列出文件內(nèi)容符合指定的樣式的文件名稱。   

    -L   --files-without-match   #列出文件內(nèi)容不符合指定的樣式的文件名稱。   

    -n   --line-number   #在顯示符合樣式的那一行之前,標(biāo)示出該行的列數(shù)編號(hào)。   

    -q   --quiet或--silent   #不顯示任何信息。   

    -r   --recursive   #此參數(shù)的效果和指定“-d recurse”參數(shù)相同。   

    -s   --no-messages   #不顯示錯(cuò)誤信息。   

    -v   --revert-match   #顯示不包含匹配文本的所有行。   

    -V   --version   #顯示版本信息。   

    -w   --word-regexp   #只顯示全字符合的列。   

    -x    --line-regexp   #只顯示全列符合的列。   

    -y   #此參數(shù)的效果和指定“-i”參數(shù)相同。

    4.規(guī)則表達(dá)式:

    grep的規(guī)則表達(dá)式:

    ^  #錨定行的開(kāi)始 如:'^grep'匹配所有以grep開(kāi)頭的行。    

    $  #錨定行的結(jié)束 如:'grep$'匹配所有以grep結(jié)尾的行。    

    .  #匹配一個(gè)非換行符的字符 如:'gr.p'匹配gr后接一個(gè)任意字符,然后是p。    

    *  #匹配零個(gè)或多個(gè)先前字符 如:'*grep'匹配所有一個(gè)或多個(gè)空格后緊跟grep的行。    

    .*   #一起用代表任意字符。   

    []   #匹配一個(gè)指定范圍內(nèi)的字符,如'[Gg]rep'匹配Grep和grep。    

    [^]  #匹配一個(gè)不在指定范圍內(nèi)的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個(gè)字母開(kāi)頭,緊跟rep的行。    

    \(..\)  #標(biāo)記匹配字符,如'\(love\)',love被標(biāo)記為1。    

    \<      #錨定單詞的開(kāi)始,如:'\

    \>      #錨定單詞的結(jié)束,如'grep\>'匹配包含以grep結(jié)尾的單詞的行。    

    x\{m\}  #重復(fù)字符x,m次,如:'0\{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。  

    POSIX字符:

    為了在不同國(guó)家的字符編碼中保持一至,POSIX(The Portable Operating System Interface)增加了特殊的字符類,如[:alnum:]是[A-Za-z0-9]的另一個(gè)寫(xiě)法。要把它們放到[]號(hào)內(nèi)才能成為正則表達(dá)式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符類。

    [:alnum:]    #文字?jǐn)?shù)字字符   

    [:alpha:]    #文字字符   

    [:digit:]    #數(shù)字字符   

    [:graph:]    #非空字符(非空格、控制字符)   

    [:lower:]    #小寫(xiě)字符   

    [:cntrl:]    #控制字符   

    [:print:]    #非空字符(包括空格)   

    [:punct:]    #標(biāo)點(diǎn)符號(hào)   

    [:space:]    #所有空白字符(新行,空格,制表符)   

    [:upper:]    #大寫(xiě)字符   

    [:xdigit:]   #十六進(jìn)制數(shù)字(0-9,a-f,A-F)  

    5.使用實(shí)例:

    實(shí)例1:查找指定進(jìn)程

    命令:

    ps -ef|grep svn

    輸出:

    [root@localhost ~]# ps -ef|grep svn

    root 4943   1      0  Dec05 ?   00:00:00 svnserve -d -r /opt/svndata/grape/

    root 16867 16838  0 19:53 pts/0    00:00:00 grep svn

    [root@localhost ~]#

    說(shuō)明:

    第一條記錄是查找出的進(jìn)程;第二條結(jié)果是grep進(jìn)程本身,并非真正要找的進(jìn)程。

    實(shí)例2:查找指定進(jìn)程個(gè)數(shù)

    命令:

    ps -ef|grep svn -c

    ps -ef|grep -c svn

    輸出:

    [root@localhost ~]# ps -ef|grep svn -c

    2

    [root@localhost ~]# ps -ef|grep -c svn 

    2

    [root@localhost ~]#

    說(shuō)明:

    實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索

    命令:

    cat test.txt | grep -f test2.txt

    輸出:

    [root@localhost test]# cat test.txt 

    hnlinux

    peida.cnblogs.com

    ubuntu

    ubuntu linux

    redhat

    Redhat

    linuxmint

    [root@localhost test]# cat test2.txt 

    linux

    Redhat

    [root@localhost test]# cat test.txt | grep -f test2.txt

    hnlinux

    ubuntu linux

    Redhat

    linuxmint

    [root@localhost test]#

    說(shuō)明:

    輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行

    實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索 且顯示行號(hào)

    命令:

    cat test.txt | grep -nf test2.txt

    輸出:

    [root@localhost test]# cat test.txt 

    hnlinux

    peida.cnblogs.com

    ubuntu

    ubuntu linux

    redhat

    Redhat

    linuxmint

    [root@localhost test]# cat test2.txt 

    linux

    Redhat

    [root@localhost test]# cat test.txt | grep -nf test2.txt

    1:hnlinux

    4:ubuntu linux

    6:Redhat

    7:linuxmint

    [root@localhost test]#

    說(shuō)明:

    輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行,并顯示每一行的行號(hào)

    實(shí)例5:從文件中查找關(guān)鍵詞

    命令:

    grep 'linux' test.txt

    輸出:

    [root@localhost test]# grep 'linux' test.txt 

    hnlinux

    ubuntu linux

    linuxmint

    [root@localhost test]# grep -n 'linux' test.txt 

    1:hnlinux

    4:ubuntu linux

    7:linuxmint

    [root@localhost test]#

    說(shuō)明:

    實(shí)例6:從多個(gè)文件中查找關(guān)鍵詞

    命令:

    grep 'linux' test.txt test2.txt

    輸出:

    [root@localhost test]# grep -n 'linux' test.txt test2.txt 

    test.txt:1:hnlinux

    test.txt:4:ubuntu linux

    test.txt:7:linuxmint

    test2.txt:1:linux

    [root@localhost test]# grep 'linux' test.txt test2.txt 

    test.txt:hnlinux

    test.txt:ubuntu linux

    test.txt:linuxmint

    test2.txt:linux

    [root@localhost test]#

    說(shuō)明:

    多文件時(shí),輸出查詢到的信息內(nèi)容行時(shí),會(huì)把文件的命名在行最前面輸出并且加上":"作為標(biāo)示符

    實(shí)例7:grep不顯示本身進(jìn)程

    命令:

    ps aux|grep \[s]sh

    ps aux | grep ssh | grep -v "grep"

    輸出:

    [root@localhost test]# ps aux|grep ssh

    root   2720  0.0  0.0  62656  1212 ?      Ss   Nov02   0:00 /usr/sbin/sshd

    root  16834  0.0  0.0  88088  3288 ?      Ss   19:53   0:00 sshd: root@pts/0 

    root  16901  0.0  0.0  61180   764 pts/0  S+   20:31   0:00 grep ssh

    [root@localhost test]# ps aux|grep \[s]sh]

    [root@localhost test]# ps aux|grep \[s]sh

    root   2720  0.0  0.0  62656  1212 ?      Ss   Nov02   0:00 /usr/sbin/sshd

    root  16834  0.0  0.0  88088  3288 ?      Ss   19:53   0:00 sshd: root@pts/0 

    [root@localhost test]# ps aux | grep ssh | grep -v "grep"

    root   2720  0.0  0.0  62656  1212 ?      Ss   Nov02   0:00 /usr/sbin/sshd

    root  16834  0.0  0.0  88088  3288 ?      Ss   19:53   0:00 sshd: root@pts/0

    說(shuō)明:

    實(shí)例8:找出已u開(kāi)頭的行內(nèi)容

    命令:

    cat test.txt |grep ^u

    輸出:

    [root@localhost test]# cat test.txt |grep ^u

    ubuntu

    ubuntu linux

    [root@localhost test]#

    說(shuō)明:

    實(shí)例9:輸出非u開(kāi)頭的行內(nèi)容

    命令:

    cat test.txt |grep ^[^u]

    輸出:

    [root@localhost test]# cat test.txt |grep ^[^u]

    hnlinux

    peida.cnblogs.com

    redhat

    Redhat

    linuxmint

    [root@localhost test]#

    說(shuō)明:

    實(shí)例10:輸出以hat結(jié)尾的行內(nèi)容

    命令:

    cat test.txt |grep hat$

    輸出:

    [root@localhost test]# cat test.txt |grep hat$

    redhat

    Redhat

    [root@localhost test]#

    說(shuō)明:

    實(shí)例11:輸出ip地址

    命令:

         ifconfig eth0|grep -E "([0-9]{1,3}\.){3}[0-9]"

    輸出:

    [root@localhost test]# ifconfig eth0|grep "[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}"

              inet addr:192.168.120.204  Bcast:192.168.120.255  Mask:255.255.255.0

    [root@localhost test]# ifconfig eth0|grep -E "([0-9]{1,3}\.){3}[0-9]"

              inet addr:192.168.120.204  Bcast:192.168.120.255  Mask:255.255.255.0

    [root@localhost test]#

    說(shuō)明:

    實(shí)例12:顯示包含ed或者at字符的內(nèi)容行

    命令:

    cat test.txt |grep -E "ed|at"

    輸出:

    [root@localhost test]# cat test.txt |grep -E "peida|com"

    peida.cnblogs.com

    [root@localhost test]# cat test.txt |grep -E "ed|at"

    redhat

    Redhat

    [root@localhost test]#

    說(shuō)明:

    實(shí)例13:顯示當(dāng)前目錄下面以.txt 結(jié)尾的文件中的所有包含每個(gè)字符串至少有7個(gè)連續(xù)小寫(xiě)字符的字符串的行

    命令:

    grep '[a-z]\{7\}' *.txt

    輸出:

    [root@localhost test]# grep '[a-z]\{7\}' *.txt

    test.txt:hnlinux

    test.txt:peida.cnblogs.com

    test.txt:linuxmint

    [root@localhost test]#

    實(shí)例14:日志文件過(guò)大,不好查看,我們要從中查看自己想要的內(nèi)容,或者得到同一類數(shù)據(jù),比如說(shuō)沒(méi)有404日志信息的

    命令:

    grep '.' access1.log|grep -Ev '404' > access2.log

    grep '.' access1.log|grep -Ev '(404|/photo/|/css/)' > access2.log

    grep '.' access1.log|grep -E '404' > access2.log

    輸出:

    [root@localhost test]# grep “.”access1.log|grep -Ev “404” > access2.log

    說(shuō)明:上面3句命令前面兩句是在當(dāng)前目錄下對(duì)access1.log文件進(jìn)行查找,找到那些不包含404的行,把它們放到access2.log中,后面去掉’v’,即是把有404的行放入access2.log

    三、Centos7 Shell腳本提示參數(shù)太多

    你在while[xxx]之前將while中括號(hào)內(nèi)的東西(xxx)打印一下看就明白了:

    echo xxx

    可能原因是其中有參數(shù)帶有特殊字符,如”[”、“]“等,你可以這樣引用參數(shù):

    while [ ${var} = ${var2} ]

    do

    ...

    如果還可能有空串的話,這樣萬(wàn)無(wú)一失:

    while [ ”X${var}“ = "X${var2}" ]

    do

    ...

    X是隨便拼上去的一個(gè)字符,目的就是保證你那個(gè)串不會(huì)是空的

    四、grep命令詳解是什么?

    可以使用head-1命令來(lái)只取grep到的數(shù)據(jù)的第一行。

    例如一個(gè)文本文檔a.txt內(nèi)容是:

    使用命令cata.txt|grep北京|head-n1可以只取到第一行的數(shù)據(jù)北京。

    -c,--bytes=[-]K;k,顯示文檔開(kāi)始的前k個(gè)字節(jié),-k,不顯示文檔結(jié)尾的最后k個(gè)字節(jié)。

    -n,--lines=[-]K:k,顯示文檔開(kāi)始的前k行,-k,不顯示文檔結(jié)尾的最后k行。

    -q,--quiet,--silent:不顯示包含給定文件名的文件頭。

    grep參數(shù)列表過(guò)長(zhǎng)(grep 參數(shù))

    命令詳解:

    head命令與tail命令用法相似,head命令用于查看文檔的開(kāi)始指定數(shù)量的字符塊,默認(rèn)顯示文檔的前10行,如果給定的文件不止一個(gè),則在顯示的每個(gè)文件前面加一個(gè)文件名標(biāo)題。

    grep命令用法格式:

    head【參數(shù)】【文件】。

    以上就是關(guān)于grep參數(shù)列表過(guò)長(zhǎng)相關(guān)問(wèn)題的回答。希望能幫到你,如有更多相關(guān)問(wèn)題,您也可以聯(lián)系我們的客服進(jìn)行咨詢,客服也會(huì)為您講解更多精彩的知識(shí)和內(nèi)容。


    推薦閱讀:

    酒店GRO(酒店gro崗位職責(zé))

    father的讀音(grandfather的讀音)

    playground(playground用on還是in)

    chatGPT的應(yīng)用(chattype)

    杭州市最有錢(qián)是哪個(gè)區(qū)(杭州最有錢(qián)的地區(qū))