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
时间: 2024-12-30 02:44:47