这篇文章主要介绍了Linux下如何使用sed命令切割文本,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
sed是一个流(stream)编辑器,每次读取文本中的一行,放到内存的缓冲区(pattern space),然后使用sed命令处理pattern space中的内容,处理完成后,默认输出至屏幕(stdout)。随后处理下一行数据。
sed替换的基本语法为:
sed 's/原字符串/替换字符串/'
单引号里面,s表示替换,三根斜线中间是替换的样式,特殊字符需要使用反斜线”\”进行转义。
单引号” ‘ ’”是没有办法用反斜线”\”转义的,这时候只要把命令中的单引号改为双引号就行了,格式如下:
# 要处理的字符包含单引号sed "s/原字符串包含'/替换字符串包含'/"
命令中的三根斜线分隔符可以换成别的符号,有时候替换目录字符串的时候有较多斜线,这个时候换成其它的分割符是较为方便,只需要紧跟s定义即可。
# 将分隔符换成问号”?”:sed 's?原字符串?替换字符串?'
可以在末尾加g替换每一个匹配的关键字,否则只替换每行的第一个,例如:
# 替换所有匹配关键字sed 's/原字符串/替换字符串/g'
一些特殊字符的使用
”^”表示行首
”$”符号如果在引号中表示行尾,但是在引号外却表示末行(最后一行)
# 注意这里的 " & " 符号,如果没有 “&”,就会直接将匹配到的字符串替换掉sed 's/^/添加的头部&/g' #在所有行首添加sed 's/$/&添加的尾部/g' #在所有行末添加sed '2s/原字符串/替换字符串/g' #替换第2行sed '$s/原字符串/替换字符串/g' #替换最后一行sed '2,5s/原字符串/替换字符串/g' #替换2到5行sed '2,$s/原字符串/替换字符串/g' #替换2到最后一行
批量替换字符串
sed -i "s/查找字段/替换字段/g" `grep 查找字段 -rl 路径`sed -i "s/oldstring/newstring/g" `grep oldstring -rl yourdir
sed处理过的输出是直接输出到屏幕上的,使用参数”i”直接在文件中替换。
# 替换文件中的所有匹配项sed -i 's/原字符串/替换字符串/g' filename
多个替换可以在同一条命令中执行,用分号”;”分隔,其格式为:
# 同时执行两个替换规则sed 's/^/添加的头部&/g;s/$/&添加的尾部/g'
感谢你能够认真阅读完这篇文章,希望小编分享的“Linux下如何使用sed命令切割文本”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!