sed ‘s///g’ 与sed ‘s///’ 其实是有很大区别的,要是不注意肯定出错,请看例子:
题目:删除一个文件里开头的空白
ps: /^ */ 匹配以空格开头的字符
/^\s/ 匹配任何空白字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]
/^[[:space:]]*/ 匹配以空格或者是\t制表符开头的字符
amp1:~ # cat 2 ##这是文件2的内容
aaaaaaaaaa
bbbbbbbbbb
cccc ccccc ccccc
dddddd dddddd dddddd
yyyyyyyy yyyyyyyyyyyyy yyyyyyyyyyyyyy
ooooooo ooooooo oooooo ooooooo
amp1:~ # sed 's/\s*//g' 2
aaaaaaaaaa
bbbbbbbbbb
cccccccccccccc
dddddddddddddddddd
yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy
ooooooooooooooooooooooooooo
##这里我们并没有定义以"\s"开头
##然后加g,结果连中间的“\s”的字符都已经匹配了
amp1:~ # sed 's/\s*//' 2
aaaaaaaaaa
bbbbbbbbbb
cccc ccccc ccccc
dddddd dddddd dddddd
yyyyyyyy yyyyyyyyyyyyy yyyyyyyyyyyyyy
ooooooo ooooooo oooooo ooooooo
##这里跟上一个相比,没有加g,结果只是匹配到了开头的“\s”字符
##说明g进行了一个全局的搜索
##不带g的话,只是匹配每行的第一个字段,后面的不管
amp1:~ # sed 's/^\s*//' 2
aaaaaaaaaa
bbbbbbbbbb
cccc ccccc ccccc
dddddd dddddd dddddd
yyyyyyyy yyyyyyyyyyyyy yyyyyyyyyyyyyy
ooooooo ooooooo oooooo ooooooo
##这里的“^”其实是多余的
##但是对于不是以空白符、制表符等开头的字符,加“^”和不加,是有很大区别的,稍后的例子会有说明。
##不带g的话,本身只会匹配开始的结果
amp1:~ # sed 's/^\s*//g' 2
aaaaaaaaaa
bbbbbbbbbb
cccc ccccc ccccc
dddddd dddddd dddddd
yyyyyyyy yyyyyyyyyyyyy yyyyyyyyyyyyyy
ooooooo ooooooo oooooo ooooooo
##这里我们指定了以“\s”开头
##然后加g,结果只会匹配第一个符合的字段,g这里也是一个全局的作用
##但是匹配的条件指定了“开头的空白”。所有结果也是正确的。
从上面的分析,可以的知道在sed命令的s模式中,g是起到一个全局的作用,这个范围是每一行,也就是说是一行为单位,作为一个全局。
+g :匹配每一行有行首到行尾的所有字符
不加g:匹配每一行的行首开始匹配,匹配到第一个符合的字段,就会结束,跳到下一行
验证:
amp1:~ # cat 3.txt ##3.txt的内容
hello hello hello
hello hello
hello hello hello
amp1:~ # sed 's/hello/nihao/' 3.txt
nihao hello hello
nihao hello
nihao hello hello
##不指定开头,也不加g,结果是匹配到一个符合的字段就直接跳到下一行
amp1:~ # sed 's/hello/nihao/g' 3.txt ##不指定开头,加g,匹配全部
nihao nihao nihao
nihao nihao
nihao nihao nihao
amp1:~ # sed 's/^hello/nihao/' 3.txt
nihao hello hello
hello hello
nihao hello hello
##指定开头,行首的第一个字段必须是"hello",所以第二行的hello不能被匹配到。
amp1:~ # sed 's/^hello/nihao/g' 3.txt ##指定开头,加全局g,同上
nihao hello hello
hello hello
nihao hello hello
网友评论