unix shell学习笔记2

2. 正则表达式与模式匹配

2.1           正则表达式

正则表达式(Regular Expression,RE)是一种字符模式,用于在查找过程中匹配指定的字符。

正则表达式元字符(通配符)

元字符/通配符

功能

例子

匹配对象

^

行首定位符

/^hello/

匹配以hello开头的

$

行尾定位符

/hello$/

匹配以hello结束的行

.

匹配单个字符

/l..e/

匹配以l开头,中间2字符并以e结尾的词

*

匹配0或多个正好在它之前的那个字符。例如正则表达式 .* 意味着能够匹配任意数量的任何字符。

/.*/

匹配任意字符

[]

匹配任意一组任意字符

/[Hh]ello/

Hellohello

[x-y]

匹配从x-y范围字符

/a[a-c]c/

aac,abc,acc

[^]

匹配不在指定组内字符

[^1-9]

不在1-9之间的字符

\

转义字符

/hello\./

hello.

 以下的在vigrep支持

\<

词首定位符

/\<love/

匹配包含love开头的行

\>

词尾定位符

/\>love/

匹配包含love结尾的行

\(..\)

 

 

 

x\{m\}

字符x重复出现m

x\{3\}

xxxa  aaaxxxb ddxxxee

x\{m,\}

字符x至少重复出现m

x\{3,\}

xxxa xxxxa

x\{m,n\}

字符x重复m次到n

x\{3,5\}

xxxa xxxxa xxxxxa

 

3. grep

3.1           grep 简介

命令格式:

grep    [-bchilnsvw]     limited-regular-expression     [filename...]

 grep global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unixgrep家族包括grepegrepfgrepegrepfgrep的命令只跟grep有很小不同。egrepgrep的扩展,支持更多的re元字符, fgrep就是fixed grepfast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux使用GNU版本的grep。它功能更强,可以通过-G-E-F命令行选项来使用egrepfgrep的功能。

grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。

grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

 

3.2   grep正则表达式元字符

grep 正则表达式的原字符集与上文的正则表达式的原字符集基本一致,这里只补充grep的正则表达式元字符集。

元字符/通配符

功能

例子

说明

\w

匹配文字和数字字符,即[A-Za-z0-9]

'G\w*p'

匹配以G后跟零个或多个文字或数字字符,然后是p

\W

\w的反置形式,匹配一个或多个非单词字

 

 

\b

单词锁定符

'\bgrep\b'

只匹配grep

 

3.3   Grep命令选

选项

功能

-b

打印匹配行前面打印该行所在的块号

-c

只打印匹配的行数,不显示匹配的内

-h

当搜索多个文件时,不显示匹配文件名前

-i

忽略大小写差

-l

打印匹配模板的文件清

-n

在匹配的行前面打印行

-s

不显示关于不存在或者无法读取文件的错误信

-v

反检索,只显示不匹配的

-w

如果被\<\>引用,就把表达式做为一个单词搜

 

3.4  

$ ls -l | grep '^a'                                通过管道过滤ls -l输出的内容,只显示以a开头的

$ grep 'test' d*                  显示所有以d开头的文件中包含test的行

 

$ grep 'test' aa bb cc       显示在aabbcc文件中匹配test的行

$ grep '[a-z]\{5\}' aa        显示所有包含每个字符串至少有5个连续小写字符的字符串的行

$ grep 'w\(es\)t.*\1' aa 如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着另外一个es\1),找到就显示该行。如果用egrepgrep -E,就不用"\"号进行转义,直接写成'w(es)t.*\1'就可以

你可能感兴趣的:(shell)