sed命令常见用法

查看文件或者目录是否存在,经常用到-d,-e,-f,其中区别如下

-e filename 如果 filename存在,则为真
-d filename 如果 filename为目录,则为真
-f filename 如果 filename为常规文件,则为真
-L filename 如果 filename为符号链接,则为真
-r filename 如果 filename可读,则为真
-w filename 如果 filename可写,则为真
-x filename 如果 filename可执行,则为真
-s filename 如果文件长度不为0,则为真
-h filename 如果文件是软链接,则为真
filename1 -nt filename2 如果 filename1比 filename2新,则为真。
filename1 -ot filename2 如果 filename1比 filename2旧,则为真。
-eq 等于
-ne 不等于
-gt 大于
-ge 大于等于
-lt 小于
-le 小于等于

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值