grep經常使用指令


1、grep 經常使用linux

grep [-acinv] '搜尋字符串' filename正則表達式

參數說明:ubuntu

-a :將 binary 檔案以 text 檔案的方式搜尋數據windows

-c :計算找到 '搜尋字符串' 的次數bash

-i :忽略大小寫的不一樣,因此大小寫視爲相同tcp

-n :順便輸出行號ide

-v :反向選擇,亦即顯示出沒有 '搜尋字符串' 內容的那一行! 測試

1.搜索特定的字符 ui

grep 'oo' pp.txt  如下僅僅用 pp 表明 pp.txt this

查看顯示字符的行數  

grep -n 'oo' pp  

查看非oo的字符 

grep -v 'oo' pp

查看大小寫忽略的字符

grep -i 'oo' p 

2.利用[]處理搜索結果

查看 tast 和 test的字符串

grep -n 't[ae]st' pp  這裏[ae]只當一個字符處理 a 或者是 e 這樣就能匹配 上面的要求 

如果但願匹配 t(x)st 這個x是任意的字符的話,那麼能夠以下處理方式

grep 't[.]st' pp  .符號表明任意的字符

 

查看包含oo字符的信息

grep -n 'oo' pp 

如果但願在oo以前沒有g的字符信息

grep -n '[^g]oo' pp 這裏的^就是取反的意思 非goo得字符 

取前面非字符的字符

grep -n '[^a-zA-Z]oo' pp  

獲得數字的字符的話

grep -n '[0-9]' pp  // 其實這個等同於  grep -n '[0-9[0-9]*' pp * 表明0個或是多個重複的信息  

3.行首和行尾的特殊處理 $^ 

如果但願取得第一行是 the 開頭的字符行

grep -n '^the' pp  

如果但願取得以英文字符開頭的字符

grep -n '^[a-zA-Z]' pp 

取得不是以英文字符開頭的信息

grep -n '^[^a-zA-Z]' pp   // 裏面的^是取反 外面的^是以上面開頭 

取得小數點結尾的行

grep -n '\.$' pp     //小數點是特殊字符 須要用\進行轉義

注意在windows下 換行時 ^M 這個符號   

取得一個空行的方式

grep -n '^$' pp 這裏就是取空行了

 

但願取得全部文檔中非註釋掉得內容的話 那麼可以下

grep -v '^$' pp|grep -v ^#        第一個是取非空行的數據

第一個管道是取非#開頭的數據

有時候更多的是取 #開頭的行

grep -n '^#' pp 

4.任意字符和重複字符

. :絕對的任意字符

* :0個或是多個相同字符 

要查看gf中間是兩個字符的數據

grep -n 'g..f' pp 

至少有一個是o的字符串

grep -n 'oo*' pp  //由於*表明0個或是多個 

以g開頭和結尾,中間至少一個o

grep -n 'goo*g'  

查找gg中間是任意字符的字符串

grep -n 'g.*g' pp 這裏.就表明任意字符 

5.限定符 {}

查看g和p之間存在兩個連個o的字符串

grep -n 'go\{2,5\}p' 

查找至少兩個的字符創

grep -n 'go\{2,\}p' pp 

查找只有兩個的字符串

grep -n 'go\{2\}p' pp 

6.重要的特殊字符

 

^word待搜尋的字符串(word)在行首!

範例:grep -n '^#' pp 搜尋行首爲 # 開始的那一行!  

word$待搜尋的字符串(word)在行尾!

範例:grep -n '!$' pp 將行尾爲 ! 的那一行打印出來! 

.表明任意的一個字符

範例; grep -n 'g.' pp 將是g開頭的兩個字符打印出來 

\將特殊字符轉義

範例:grep -n \' pp  搜索有單引號的那一行 

*:匹配0個或是多個字符

grep -n 'o*' pp 匹配擁有零個或是多個o的字符

\{n,m\} :匹配的個數

grep -n 'o\{2\}' pp 打印出擁有兩個oo的字符

[]匹配單個字符 

  1.[list] : [abl] 匹配 abl中任意一個

  2.[^xx]:對其中的字符進行取反  這裏只能對的那個字符進行取反 如果但願是多個字符取反的話 還須要看看

  3.[char1-char2]:匹配某個範圍以內的數據 例如 [a-z][A-Z][0-9]

7.擴張的grep --- > egrep  這個等同於 grep -E  

grep -v '^$' pp | grep -v '^#'

經過egrep來表示就是

egrep -v '^$|^' 

8.查找內容有「或」的關係:

#查找數字爲23或24的內容,並顯示內容與行號

grep -E '23|24' * -n

 

9.查找data.txt文件有多少個空行:

grep '^$' data.txt -c 

10.查詢當前目錄中還有多少個目錄:

ls -l | grep ^d'

11.查找data.txt文件字符串尾部爲a的內容

grep 'a$' data.txt -i -n 

$ grep "sort it" *      (#或在全部文件中查詢單詞「sort it」)
接下來的全部示例是指在單個文件中進行查詢
 行匹配
$ grep -c "48" data.f
$ 4          (#grep返回數字4,意義是有4行包含字符串「4 8」。)
$ grep "48" data.f          (#顯示包含「4 8」字符串的4行文本)

顯示知足匹配模式的全部行行數:
[lxj@localhost lxjwork]$ cat file

123bjk456

345yui678

789hiy123

[lxj@localhost lxjwork]$ grep -n 123 file

1:123bjk456

3:789hiy123

6. 精確匹配
[lxj@localhost lxjwork]$ cat file

123bjk456

345yui678

789hiy123

[lxj@localhost lxjwork]$ grep "123\>" file

789hiy123

7. 查詢空行,查詢以某個條件開頭或者結尾的行。
結合使用^和$可查詢空行。使用- n參數顯示實際行數
[[lxj@localhost lxjwork]$ grep -n "^$" file

2:

[lxj@localhost lxjwork]$ cat file

123bjk456

 

345yui678

789hiy123

(返回結果 2:   #說明第二行是空行)
[lxj@localhost lxjwork]$ cat file

123bjk456

abc1233jk

345yui678

auhushabc

789hiy123

[lxj@localhost lxjwork]$ grep -n "^abc" file

2:abc1233jk

(#查詢以abc開頭的行)
[lxj@localhost lxjwork]$ grep -n "abc$" file

4:auhushabc

(#查詢以abc結尾的行)

8. 匹配特殊字符,查詢有特殊含義的字符,諸如$ . ' " * [] ^ | \ + ? ,必須在特定字符前加\。
[lxj@localhost lxjwork]$ cat file

.jdhk

dhhdj

a.djk

789hiy123

[lxj@localhost lxjwork]$ grep "\." file

.jdhk

a.djk

(#在file中查詢包含「.」的全部行)
[lxj@localhost lxjwork]$ cat file

.jdhk

dhhdj

my.conf

dbhjbjj

789hiy123

[lxj@localhost lxjwork]$ grep "my.conf" file

my.conf

(#查詢有文件名my. c o n f的行)

9. 目錄的查詢
[lxj@localhost lxjwork]$ ls -l | grep "^d"

drwxrwxr-x. 2 lxj  lxj  4096 5月  28 03:38 epoll

drwxrwxr-x. 2 lxj  lxj  4096 4月  13 07:21 pipe

drwxrwxr-x. 2 lxj  lxj  4096 6月  21 18:02 pthread

drwxrwxr-x. 2 lxj  lxj  4096 6月  21 19:33 rwlock

drwxrwxr-x. 2 lxj  lxj  4096 5月  26 05:21 select

drwxrwxr-x. 2 lxj  lxj  4096 6月  20 07:44 sem

drwxrwxr-x. 2 lxj  lxj  4096 6月  20 18:06 shm

drwxrwxr-x. 2 lxj  lxj  4096 5月  21 03:06 tcp

drwxrwxr-x. 2 lxj  lxj  4096 5月  20 18:08 udp

(#若是要查詢目錄列表中的目錄)
[lxj@localhost lxjwork]$ ls -l | grep "^d[d]"

(#在一個目錄中查詢不包含目錄的全部文件)

10.排除自身

ps -ef|grep telnet | grep -v grep (在顯示的進程中抽出「telnet」進程;並丟棄ps中的grep進程) 

egrep的幾個特殊字符

+ :至少一個或是多個   egrep -n 'go+d' pp

?:0個或是一個        egrep -n 'go?d' pp

| :用或的方式來查找   egrep -n 'go|good' pp 查找go或是good

():找出羣組的數據      egrep -n 'g(o|pp)d' pp 查看god 或是gppd  這個相似於 [] 可是比[]強大的是能夠是多個字符進行亂換

egrep -n 'd(r|o)e' pp  ===== grep -n 'd[ro]e' pp


2、總結:

1. grep最簡單的使用方法,匹配一個詞:grep word filename

2. 能夠從多個文件中匹配:grep word filename1 filenam2 filename3

3. 能夠使用正則表達式匹配:grep -E pattern f1 f2 f3...

4. 能夠使用-o只打印匹配的字符,以下所示:

[lxj@localhost lxjwork]$ echo this is a line. | grep -E -o "[a-z]*\."

line.

5. 打印除匹配行以外的其餘行,使用-v

[lxj@localhost lxjwork]$ echo -e "1\n2\n3\n4" | grep -v -E "[1-2]"

3

4

6. 統計匹配字符串的行數,使用-c

[lxj@localhost lxjwork]$ echo -e "1\n3\n\4\n\2" | grep -o -E "[1-2]" -c

2

7. 若是咱們統計字符串模式匹配的次數,能夠結合-o和-c,以下:

[lxj@localhost lxjwork]$ echo -e "1\n3\n\4\n\2" | grep -o -E "[1-2]" |wc

      2       2       4

 

8. 若是須要顯示行號,能夠打開-n,以下:

[lxj@localhost lxjwork]$ echo -e "1\n3\n\4\n\2" | grep -n -E "3"

2:3

9. -b選項能夠打印出匹配的字符串想對於其所在的行起始位置的偏移量(從0開始),一般配合-o使用,以下:

[lxj@localhost lxjwork]$ echo "0123456789" | grep -b -o 5

5:5

10. 當字符串在多個文件中匹配時,-l選項將只打印文件名

11. -L與-l相對,只打印不匹配的文件名

[lxj@localhost lxjwork]$ cat file1

linux

is

fun

[lxj@localhost lxjwork]$ cat file2

a

very

popular

os,

linux

[lxj@localhost lxjwork]$ cat file3

what

the

fxxk

[lxj@localhost lxjwork]$ grep -l linux file1 file2 file3

file1

file2

[lxj@localhost lxjwork]$ grep -L linux file1 file2 file3

file3

12. 打開遞歸搜索功能

lichao@ubuntu:command$ grep -n -R linux .

[lxj@localhost lxjwork]$ grep -n -R linux .

匹配到二進制文件 ./sem/test

匹配到二進制文件 ./shm/client

匹配到二進制文件 ./shm/server

匹配到二進制文件 ./select/client_select

匹配到二進制文件 ./select/server_select

./file1:1:linux

匹配到二進制文件 ./pipe/p.c

匹配到二進制文件 ./pipe/p

匹配到二進制文件 ./pipe/p2

匹配到二進制文件 ./pipe/p4

匹配到二進制文件 ./pipe/p3

匹配到二進制文件 ./pipe/p1

匹配到二進制文件 ./pipe/p4.c

匹配到二進制文件 ./tcp/tcp_client

匹配到二進制文件 ./tcp/tcp_server

匹配到二進制文件 ./epoll/epoll_sever

匹配到二進制文件 ./rwlock/rwlock

匹配到二進制文件 ./pthread/exit

匹配到二進制文件 ./pthread/my_pthread

匹配到二進制文件 ./pthread/mutext_lock

匹配到二進制文件 ./pthread/pro_con

匹配到二進制文件 ./pthread/detach

./file2:5:linux

13. 忽略大小寫:-i

[lxj@localhost lxjwork]$ echo "HELLO WORLD" | grep -i "hello"

HELLO WORLD

14. 匹配多個字符串模式

[lxj@localhost lxjwork]$ echo "this is a line" | grep -e "this" -e "is" -e "line" -o

this

is

line

15. 用單獨的文件提供匹配樣式,每一個匹配的樣式做爲一行,以下例所示:

[lxj@localhost lxjwork]$ cat file1

1$

2

3

[lxj@localhost lxjwork]$ cat file2

1

2

3

4

5

6

7

8

9

10

[lxj@localhost lxjwork]$ grep -f file1 file2

1

2

3

16. 打印匹配行上下文信息,使用 -A n打印匹配行及其後n行信息;使用-B n打印匹配行及其前n行信息;使用 -C n,打印匹配行及其先後n行信息;若是有多重匹配,將使用--隔離。示例以下:

[lxj@localhost lxjwork]$ seq 1 10 | grep 5 -A 3

5

6

7

8

[lxj@localhost lxjwork]$ seq 1 10 | grep 5 -B 3

2

3

4

5

[lxj@localhost lxjwork]$ seq 1 10 | grep 5 -C 3

2

3

4

5

6

7

8

[lxj@localhost lxjwork]$ echo -e "a\nb\nc\nd\na\nb\nc\nd\n" | grep a -A 2

a

b

c

--

a

b

c

17. 使用-q進入靜默模式,該模式下,grep命令運行目的僅僅是執行一個條件測試,一般在腳本中使用。經過檢查其返回值進行下一步操做。示例以下:

[lxj@localhost lxjwork]$ cat file

hello

world

[lxj@localhost lxjwork]$ cat tmp.sh

#!/bin/bash

if [ $# -ne 2 ]; then

echo "Usage: $0 match_pattern file_name"

exit

fi

match=$1

file=$2

grep -q $match $file

if [ $? -ne 0 ]; then

echo "$match not exist in $file"

else

echo "$match exist in $file"

fi

[lxj@localhost lxjwork]$ ./tmp.sh hello file

hello exist in file

上即爲grep經常使用的選項。

相關文章
相關標籤/搜索