根据某个文件的关键字做替换
#!/bin/bash
kv=`awk -F "=" '{ if(NF==2) print $1"="$2 }' ./zuanshi_servic_test.properties`
for kv in ${kv[@]};do
k=`echo $kv | awk -F "=" '{print $1}'`
v=`echo $kv | awk -F "=" '{print $2}' | awk -F "\r" '{print $1}'`
sed -i "s@\${$k}@$v@g" `grep $k -rl ./src/test/resources/`
done
原本打算将sed跟awk混合使用的,但是最后还是没成功,只好退而求其次,先将key-value保存到kv数组中,然后根据key依次替换对应文件。
因为value中包含"\"等字符,所以原本使用的sed 's/XX/XX/g'无法正常使用,改为's@XX@XX@g'
另外学到了Bash中的for循环${kv[@]}
另外一开始,脚本一致性就报错,但是看代码又看不出任何错误。最后才知道,原来这个脚本是通过svn windows客户端上传的,在Linux下需要通过dos2unix进行转换才能使用,而从代码上是看不出任何差别的。不能被表象迷惑啊。
本文详细介绍了如何在Bash脚本中使用sed和awk进行复杂的数据替换操作,包括将关键字转换为值并替换文件内容的方法。文章还讨论了在不同操作系统环境下脚本的一致性问题,以及使用dos2unix进行转换的重要性。此外,文章还分享了在处理包含特殊字符的值时,sed命令的正确语法,并提到了Bash中的for循环和kv数组的应用。
1642

被折叠的 条评论
为什么被折叠?



