Linux学习笔记01
删除一个文本文件的内容:
删除:d命令
$ sed ‘2d’ test01-----删除test01文件的第二行。
$ sed ‘2,$d’ test01-----删除test01文件的第二行到末尾所有行。
$ sed ‘$d’ test01-----删除test01文件的最后一行。
$ sed '/test/'d test01-----删除test01文件所有包含test的行。
-
删除固定内容:
sed -i '/****/d' 123.txt
-
如果删除的是一个变量的值,假如变量是char,应该写成:
sed -i '/'"$char"'/d' 123.txt
-
至于grep -v **** 123.txt这个方法,是无法将修改的结果写入123.txt中去的–待测
-
用‘/d’的语句,会删除包含值的所有行。
替换:s命令
在看看sed ‘s/|/,/g’ aaa.txt>bbb.txt 这个的意思就是把aaa.txt文件中所有字符串|都换成,这是怎么表示的呢?S代表字符串,g表示行内全面替换。
$ sed ‘s/test/mytest/g’ example
-----在整行范围内把test替换为mytest。如果没有g标记,则只有每行第一个匹配的test被替换成mytest。
$ sed -n ‘s/^test/mytest/p’ example
-----(-n)选项和p标志一起使用表示只打印那些发生替换的行。也就是说,如果某一行开头的test被替换成mytest,就打印它。
$ sed ‘s/^192.168.0.1/&localhost/’ example
-----&符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost。
$ sed -n ‘s/able/\1rs/p’ example
-----love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。
$ sed ‘s#10#100#g’ example
-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。