主要功能,对文本进行替换,删除,新增和选取等工作;
以下命令并不会改变源文件的内容,只是改变输出形式
sed的拼接命令 -e:
sed -e ‘$a hello’ -e ’ $a world’ b1.txt:向b1.txt末尾追加‘hello’和‘world’
$符号表示末尾,a表示追加
sed的插入命令 ni(n表示行号i表示插入insert)
sed ‘2i hello’ b1.txt :表示向b1.txt的第2行插入hello;
sed的删除命令d
sed ‘nd’ b1.txt:表示删除第n行的内容,n也可用$ 替换,表示删除最后一行,n也可以用其他表示范围的正则表达式替换(应该吧,不清楚)
sed的查询命令p
例1:
sed -n ‘1p’ b1.txt:表示查询b1.txt第一行的内容,-n不能少,少了会使查询出来的结果多了完整的原文件的内容。同上面一样n也可以用$ ,(m,n)表示相应的范围,(m,n)表示从m到n
例二:
sed -n ‘/oracle/p’ b1.txt:表示查找含有oracle字样的行
例三:
sed -n ‘/$oracle/p’ b1.txt:表示查找匹配KaTeX parse error: Undefined control sequence: \是 at position 11: oracle的字样,\̲是̲转义符,不使用转义符,会按特殊字符处理,使得查找出结果变成先输出原来文件里的内容,最后在输出匹配的内容(此处我遇到一个问题,加-n 的时候会解决输出原来内容的问题,不加-n就会出现上述问题)
例四:
sed 的 -n的使用:
情况一:-n只会显示匹配处理的行(否则输出所有行)
sed -n ‘/$oracle/p’ b1.txt
sed -n ‘/oracle/p’ b1.txt
情况二:匹配行号
sed -n ‘1p’ b1.txt
sed -n ‘$p’ b1.txt
sed的修改命令
要想真正修改文件内的内容,需要使用-i子命令
sed -i ‘1s/hello/hi/’ b1.txt:能真正修改b1.txt的内容
情况一:
sed '1c hello ’ b1.txt:表示将第一行修改为hello
sed ‘m,nc hello’ b1.txt:表示将从第m到n行的多行内容修改为hello的一行内容;
情况二:(精确匹配法)
sed ‘m,ns /hello/hill/’ b1.txt:表示将m到n行所有匹配hello 的行全部换为hill。
分隔符
‘/’表示分隔符
有时例如在使用sed 的s子命令时,如果出现特殊字符转义的话,我们可以使用其他字符例如#来代替分隔符,前提是该其他字符没有特殊含义;
通配符:
.表示任意一个字符
*表示按要求匹配前面的字符:
举例:
ab * 表示匹配a或匹配ab
sed实验:
sed关闭selinux
seLinux:selinux是由美国海军开发,可能会莫名其妙的拦截我们的正常信息,在生产中,Oracle和MySQL会以集群的形式出现,所以为了集群网络的安全和畅通性,建议关闭该防火墙;
方法一:精确匹配
sed ‘s#SELINUX=enforcing#SELINUX=disabled#’ /etc/selinux/config
方法二:正则匹配法(我感觉像是用通配符匹配,而不是正则)
sed ‘s#SELINUX=.*#SELINUX=disabled#g’ /etc/selinux/config
g代表全部替换,正则表达式找到的全部替换。若不加g,当一行中出现多个与正则表达式匹配的内容时,只会去替换第一与正则表达式相匹配的