#!/bin/sh
old="hello"
new="world"
sed -i s/"${old}"/"${new}"/g $(grep "${old}" -rl *)
前面的脚本只适用于单行文本,如何编写可替换的脚本 多行文字。
old='line1
line2
line3'
new='newtext1
newtext2'
我可以使用什么命令。
答案 0 :(得分:1)
awk
可以为您做到这一点。
awk 'BEGIN { RS="" }
FILENAME==ARGV[1] { s=$0 }
FILENAME==ARGV[2] { r=$0 }
FILENAME==ARGV[3] { sub(s,r) ; print }
' FILE_WITH_CONTENTS_OF_OLD FILE_WITH_CONTENTS_OF_NEW ORIGINALFILE > NEWFILE
但您可以使用vim
like described here(可编写脚本的解决方案)来完成此操作。
答案 1 :(得分:1)
您可以使用perl或awk,并将记录分隔符更改为换行符以外的其他内容(这样您就可以匹配更大的块。例如使用awk:
echo -e "one\ntwo\nthree" | awk 'BEGIN{RS="\n\n"} sub(/two\nthree\n, "foo")'
或使用perl(-00 ==段落缓冲模式)
echo -e "one\ntwo\nthree" | perl -00 -pne 's/two\nthree/foo/'
我不知道是否有可能根本没有记录分隔符(使用perl,你可以先读取整个文件,但是再次对内存使用情况不太好)