新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
grep命令:
成都创新互联自2013年起,是专业互联网技术服务公司,拥有项目成都网站设计、成都网站建设、外贸网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元河西做网站,已为上家服务,为河西各地企业和个人服务,联系电话:18980820575
模版:
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