去除空行与#开头的行
grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次
下面使用扩展正则表达式
egrep -v '^$|^#' a.txt
+ 重复一个或一个以上的字符
搜索god good goood等字符串,o+代表一个以上的o
egrep -n 'go+d' a.txt
? 0个或1个字符
搜索gd 或者 god字符串的行
egrep -n 'go?d' a.txt
| 用或(or)的方式找出数个字符串
egrep -n 'gd|good' a.txt
找出含有gd或者god的字符串的行
() 找出含有glad或good或gaad或glod这两个字符串的行
egrep -n 'g(la|oo|aa|lo)' a.txt
!在正则表达式中不是特殊字符
查找出含有(!)与(>)的行
grep -n '[!>]' a.txt
RE 字符 | 意义与范例 |
+ | 重复『一个或一个以上』的前一个 RE 字符 |
范例:egrep -n 'go+d' regular_express.txt 搜寻 (god) (good) (goood)... 等等的字符串。 那个 o+ 代表『一个以上的 o 』所以,上面的执行成果会将第 1, 9, 13 行列出来。 | |
? | 『零个或一个』的前一个 RE 字符 |
范例:egrep -n 'go?d' regular_express.txt 搜寻 (gd) (god) 这两个字符串。 那个 o? 代表『空的或 1 个 o 』所以,上面的执行成果会将第 13, 14 行列出来。 有没有发现到,这两个案例( 'go+d' 与 'go?d' )的结果集合与 'go*d' 相同? 想想看,这是为什么喔! ^_^ | |
| | 用或( or )的方式找出数个字符串 |
范例:egrep -n 'gd|good' regular_express.txt 搜寻 gd 或 good 这两个字符串,注意,是『或』! 所以,第 1,9,14 这三行都可以被打印出来喔!那如果还想要找出 dog 呢?就这样啊: egrep -n 'gd|good|dog' regular_express.txt | |
( ) | 找出『群组』字符串 |
范例:egrep -n 'g(la|oo)d' regular_express.txt 搜寻 (glad) 或 (good) 这两个字符串,因为 g 与 d 是重复的,所以, 我就可以将 la 与 oo 列于 ( ) 当中,并以 | 来分隔开来,就可以啦! 此外,这个功能还可以用来作为『多个重复群组』的判别喔!举例来说: echo 'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C' 上面的例子当中,意思是说,我要找开头是 A 结尾是 C ,中间有一个以上的 "xyz" 字符串的意思~ |
以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
- grep -n '[!>]' regular_express.txt
去除空行与#开头的行
以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次
下面使用扩展正则表达式
egrep -v '^$|^#' a.txt
+ 重复一个或一个以上的字符
搜索god good goood等字符串,o+代表一个以上的o
egrep -n 'go+d' a.txt
? 0个或1个字符
搜索gd 或者 god字符串的行
egrep -n 'go?d' a.txt
| 用或(or)的方式找出数个字符串
egrep -n 'gd|good' a.txt
找出含有gd或者god的字符串的行
() 找出含有glad或good或gaad或glod这两个字符串的行
egrep -n 'g(la|oo|aa|lo)' a.txt
!在正则表达式中不是特殊字符
查找出含有(!)与(>)的行
grep -n '[!>]' a.txt
RE 字符 | 意义与范例 |
+ | 重复『一个或一个以上』的前一个 RE 字符 |
范例:egrep -n 'go+d' regular_express.txt 搜寻 (god) (good) (goood)... 等等的字符串。 那个 o+ 代表『一个以上的 o 』所以,上面的执行成果会将第 1, 9, 13 行列出来。 | |
? | 『零个或一个』的前一个 RE 字符 |
范例:egrep -n 'go?d' regular_express.txt 搜寻 (gd) (god) 这两个字符串。 那个 o? 代表『空的或 1 个 o 』所以,上面的执行成果会将第 13, 14 行列出来。 有没有发现到,这两个案例( 'go+d' 与 'go?d' )的结果集合与 'go*d' 相同? 想想看,这是为什么喔! ^_^ | |
| | 用或( or )的方式找出数个字符串 |
范例:egrep -n 'gd|good' regular_express.txt 搜寻 gd 或 good 这两个字符串,注意,是『或』! 所以,第 1,9,14 这三行都可以被打印出来喔!那如果还想要找出 dog 呢?就这样啊: egrep -n 'gd|good|dog' regular_express.txt | |
( ) | 找出『群组』字符串 |
范例:egrep -n 'g(la|oo)d' regular_express.txt 搜寻 (glad) 或 (good) 这两个字符串,因为 g 与 d 是重复的,所以, 我就可以将 la 与 oo 列于 ( ) 当中,并以 | 来分隔开来,就可以啦! 此外,这个功能还可以用来作为『多个重复群组』的判别喔!举例来说: echo 'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C' 上面的例子当中,意思是说,我要找开头是 A 结尾是 C ,中间有一个以上的 "xyz" 字符串的意思~ |
以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
- grep -n '[!>]' regular_express.txt