如何替换束文件中的多行字符串

时间:2012-02-10 11:06:34

标签: linux bash

#!/bin/sh
old="hello"
new="world"
sed -i s/"${old}"/"${new}"/g $(grep "${old}" -rl *)

前面的脚本只适用于单行文本,如何编写可替换的脚本 多行文字。

old='line1
line2
line3'

new='newtext1
newtext2'

我可以使用什么命令。

2 个答案:

答案 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(可编写脚本的解决方案)来完成此操作。

另请参阅sed常见问题解答中的thisthis

答案 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,你可以先读取整个文件,但是再次对内存使用情况不太好)