查看文件或者目录是否存在,经常用到-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 |