grep命令基本用法:
1.grep程序按照如下方式接受选项和参数。
grep [options] regex [file...] #其中字符串regex代表的是某个正则表达式。
2.grep选项功能描述
3.文字字符和元字符
(1)文字字符:
除了元字符其他所有字符被当作文字字符。(反斜杠字符可用来创建元序列)
(2)元字符:用于指定更加复杂的匹配的元字符
^ $ . [ ] { } - ? * + ( ) | \
4.元字符匹配规则
(1)任意字符: .
元字符是“点"字符或者句点字符,该字符用于匹配.任意字符。如果将其加进某个正则表达式中,它将会在对应位置匹配任意字符。
grep -n *San datebook.txt #匹配datebook.txt文件中包含所有以San结尾的字符所在行
(2)锚: ^ $
插入符(^)和美元符号( ) 在 正 则 表 达 式 被 当 做 锚 , 也 就 是 说 正 则 表 达 式 只 与 行 的 开 头 ( ) 或 是 末 尾 ( ) 在正则表达式被当做锚,也就是说正则表达式只与行的开头(^)或是末尾( )在正则表达式被当做锚,也就是说正则表达式只与行的开头()或是末尾()的内容进行匹配比较。
grep -n '^San' datebook.txt #匹配以San开头的所在行
grep -n '^San' datebook.txt #匹配以San结尾的所在行
grep -n '^$' datebook.txt #匹配空行
grep -n '^K.r.n$' datebook.txt #匹配第一个字母是K,第三个r第五个是n的字符
(3)中括号表达式:[ ]
中括号除了可以用于匹配正则表达式中给定位置的任意字符外,还可以用于匹配指定字符集中的单个字符。借助于中括号,我们可以指定要匹配的字符集(也包括那些可能会被解释为元字符的字符)。如下命令行则利用了一个两个字母组成的字符集,用于匹配包含San或san字符串的文本行。
grep '[Ss]an' datebook.txt #匹配包含San或san字符
一个字符集可以包含任意数目的字符,并且当元字符放置到中括号中时, .会失去它们的特殊含义,然而,在两种情况下,则会在中括号中使用元字符,并且会有不同的含义。
第一个就是插入符(^), 它在中括号内使用表示否定;
另外一个是连字符(-), 它表示字符范围。
(4)否定:^
如果中括号内的第一-个字符是插入符 (^), 那么剩下的字符则被当作不应该在指定位置出现的字符集。
grep '[^Ss]an' datebook.txt #匹配包含San或san字符
注意:插入符号 “^” 只有是中括号表达式中的第一 个字符时才会被当作否定符,如果不是第一个 “^” ,将会丧失其特殊含义而成为普通字符。
(5)或选项: |
或选项则用于从字符串集或正则表达式集中寻找匹配项。
root@Autumn:/$ echo "San" | grep -E 'San|san' #echo的输出与San匹配,成功则输出
San
root@Autumn:/$ echo "san" | grep -E 'San|san'
san
由于此处使用的是扩展特性,所以grep增加了-E选项(虽然可以使用egrep 命令来代替),并且**将正则表达式用引号引起来以防止shell将元字符“|"当作管道操作符来处理。**另外,或选项并不局限于两种选择,还可以有更多的选择项。