linux批量替换文件内容3种方法(perl,sed,shell)

这两天调整ecos百科全书百度统计js代码时,由于project很大,足足有300多个**.html文件,想到有几个不错的命令,特来分享一下。

方法1:perl

find -name '要查找的文件名' | xargs perl -pi -e 's|被替换的字符串|替换后的字符串|g'

简化替换百度统计写法如下:

find -name '*.html' | xargs perl -pi -e 's|10df773df544a42f4bf40f5b40c30b57|0570ad559ad25dcb85c076343e15df53|g'

方法2:sed

sed -i "s/原字符串/新字符串/g" `grep 原字符串 -rl 所在目录`

简化替换百度统计写法如下:

sed -i "s/10df773df544a42f4bf40f5b40c30b57/0570ad559ad25dcb85c076343e15df53/g" 'grep10df773df544a42f4bf40f5b40c30b57 -rl /ecos'

方法3:grep

在日程的开发过程中,可能大家会遇到将某个变量名修改 为另一个变量名的情况,如果这个变量是一个局部变量的话,vi足以胜任,但是如果是某个全局变量的话,并且在很多文件中进行了使用,这个时候使用vi就是 一个不明智的选择。这里给出一个简单的shell命令,可以一次性将所有文件中的指定字符串进行修改:

grep "abc" * -R | awk -F: '{print $1}' | sort | uniq | xargs sed -i 's/abc/abcde/g'