sed 替换文档里的字符

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章