shell脚本三剑客之grep命令

grep命令:


模版:

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.

P.Bunny   02/99 48    Yellow  12 35 2658

J.Troll   07/99 4842  Brown-3 12 26 266666

L.Tansley 05/99 4712  Brown-2 12 30 44544


单双引号:

在匹配模式时需要有单引号。

在匹配字符串(“123 ABC”,如果不加双引号grep命令会将ABC当成文件。)和变量时需要用双引号。


grep允许使用国际字符模式匹配或匹配模式的类名形式。

类名及其等价的正则表达式

类等价的正则表达式 

[[ : u p p e r : ]] [ A - Z ] 

[[ : a l n u m : ]] [ 0 - 9 a - zA-Z]

[[ : l o w e r : ]] [ a - z ] 

[[ : s p a c e : ]] 空格或t a b键

[[ : d i g i t : ]] [ 0 - 9 ] 

[[ : a l p h a : ]] [ a - z A - Z ]


参数:

-c:计算匹配模式的个数。

例:[root@localhost GREP]# grep -c Green data.f 

1


-i:不区分大小写。

例:[root@localhost GREP]# grep -i green data.f 

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.

    [root@localhost GREP]# grep "[Gg]reen" data.f    释:也可以用范围模式来匹配,单引号也可以。

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.


-h:在多个文件中匹配模式,忽略文件名。

例:[root@localhost GREP]# grep green data.f data.f.bak 

data.f:J.Lulu    06/99 48317 green   9  24 2678.

data.f.bak:J.Lulu    06/99 48317 green   9  24 2678.

    [root@localhost GREP]# grep -h green data.f data.f.bak 

J.Lulu    06/99 48317 green   9  24 2678.

J.Lulu    06/99 48317 green   9  24 2678.


-l:显示匹配模式的所在文件。

例:[root@localhost GREP]# grep -l green data.f data.f.bak 

data.f

data.f.bak

    [root@localhost GREP]# grep -l green *释:“*” 查找当前目录下所有文件也可以"*.后缀名"这样使用,对其匹配。

data.f

data.f.bak


-n:显示匹配模式的行号。

例:[root@localhost GREP]# grep -n green data.f

2:J.Lulu    06/99 48317 green   9  24 2678.


-s:忽略因文件不存在返回的信息。

例:[root@localhost GREP]# grep green ABC     释:在本目录下没有ABC个文件,所以返回错误信息。加-s参数后错误信息忽略。

grep: ABC: 没有那个文件或目录

    [root@localhost GREP]# grep -s green ABC

    [root@localhost GREP]# echo $?

2


-v:反查找信息。

例:[root@localhost GREP]# cat data.f.bak     释:用变量代替所要匹配的模式。

green

Yellow

    [root@localhost GREP]# AAA=`cat data.f.bak`

    [root@localhost GREP]# echo $AAA

green Yellow

    [root@localhost GREP]# grep -v "$AAA" data.f

M.Tansley 05/99 48311 Green   8  40 44.44

J.Troll   07/99 4842  Brown-3 12 26 266666

L.Tansley 05/99 4712  Brown-2 12 30 44544



精确匹配:

例:[root@localhost GREP]# grep "48\>" data.f

P.Bunny   02/99 48    Yellow  12 35 2658


范围匹配:

例:[root@localhost GREP]# grep "48[34]" data.f     释:“[]”可以用来指定字符串范围。

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.

J.Troll   07/99 4842  Brown-3 12 26 266666


是否匹配行首:

例:[root@localhost GREP]# grep "^[^J]" data.f      释:如果要抽其行首不是48,可以在方括号中使用^记号,表明查询在行首开始。

M.Tansley 05/99 48311 Green   8  40 44.44

P.Bunny   02/99 48    Yellow  12 35 2658

L.Tansley 05/99 4712  Brown-2 12 30 44544

例:[root@localhost GREP]# grep "^J" data.f         释:“^”如果是已什么来开头就用这个符号。

J.Lulu    06/99 48317 green   9  24 2678.

J.Troll   07/99 4842  Brown-3 12 26 266666


任意匹配:

例:[root@localhost GREP]# grep "B.....2" data.f    释:“.”点代表一位任意数。“*”代表多位任意数。

L.Tansley 05/99 4712  Brown-2 12 30 44544       样例中表示已B开头已2结尾和已B开头已任意数结尾。

    [root@localhost GREP]# grep "B.....[1-9]" data.f

J.Troll   07/99 4842  Brown-3 12 26 266666

L.Tansley 05/99 4712  Brown-2 12 30 44544

    [root@localhost GREP]# grep "J...[a-z,A-Z][a-z,A-Z]" data.f    释:

J.Lulu    06/99 48317 green   9  24 2678.

J.Troll   07/99 4842  Brown-3 12 26 266666

    [root@localhost GREP]# grep "[a-z,A-Z]....ll" data.f     已逗号做分隔符

J.Troll   07/99 4842  Brown-3 12 26 266666


模式定位查找:

例:[root@localhost GREP]# grep '[A-Z,a-Z]\{5\}[w]' data.f      释:查找5位字母(a-z和A-Z)并是已w结尾的模式,因为这是匹配的模式所以要用单引号

P.Bunny   02/99 48    Yellow  12 35 2658


模式随机查找:

例:[root@localhost GREP]# grep '2\{1,6\}6' data.f释:在文件中查找重复出现1~6次数字2并且这数字是已6结尾(26、226、2226以此类推出现六次)

J.Lulu    06/99 48317 green   9  24 2678.

P.Bunny   02/99 48    Yellow  12 35 2658

J.Troll   07/99 4842  Brown-3 12 26 266666

例:[root@localhost GREP]# grep '4\{1,10\}7' data.f

L.Tansley 05/99 4712  Brown-2 12 30 44544



范围组合:

例:[root@localhost GREP]# grep "^[A-Z].[AB].*" data.f    释:【A-Z】代表一位的任意字母后面的“.”点代表任意字符,【AB】代表这一位只能是两个字母A和B,后面的“.*”多位任意数。

P.Bunny   02/99 48    Yellow  12 35 2658


空行和转意:

例:[root@localhost GREP]# grep '^$' data.f

例:[root@localhost GREP]# grep 'J\.Troll' data.f释:查询有特殊含义的字符,要在特定字符前加“\”

J.Troll   07/99 4842  Brown-3 12 26 266666


grep -E 参数:

例:[root@localhost GREP]# grep -E --color=auto  '[A-Z,a-z]reen|[A-Z]ellow' data.f     释:egrep是grep的一种扩展用法,增加额为匹配模式,--color=auto 为匹配的模式添加颜色

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.

P.Bunny   02/99 48    Yellow  12 35 2658

    [root@localhost GREP]# grep --color=auto '[A-Z,a-z]reen\|[A-Z]ellow' data.f释:在竖杠前加转意也能达到egrep的用途。

M.Tansley 05/99 48311 Green   8  40 44.44

J.Lulu    06/99 48317 green   9  24 2678.

P.Bunny   02/99 48    Yellow  12 35 2658


类名及其等价的正则表达式:

例:[root@localhost GREP]# grep '[[:upper:]]reen' data.f

M.Tansley 05/99 48311 Green   8  40 44.44

例:[root@localhost GREP]# grep 'J\.[[:upper:]]' data.f

J.Lulu    06/99 48317 green   9  24 2678.

J.Troll   07/99 4842  Brown-3 12 26 266666


egrep -f参数用法:

例:[root@localhost GREP]# cat data.f.bak

green

Yellow

266666

    [root@localhost GREP]# egrep -f data.f.bak data.f     释:egrep可以将文档里保存的字符串用作自己使用的参数,并用-f开启功能。

J.Lulu    06/99 48317 green   9  24 2678.

P.Bunny   02/99 48    Yellow  12 35 2658

J.Troll   07/99 4842  Brown-3 12 26 266666



你可能感兴趣的:(grep命令)