我需要使用带有模式的其他文件(如字符串数据库)替换许多文件中的许多字符串。它用于匿名化文件。
示例:
文件#1:
"Administrator";"512";"Built-in account for administering the computer/domain";"False";"False";"Administrator";"True";"True";"True";"S-1-5-21-3445027559-693823181-3401817782-500";"User";"OK";"23. 1. 2012 9:41:34";"20. 1. 2012 16:01:33";"10";"True";*
文件#2(模式文件):
Guest;user1
Administrator;user2
system;user3
文件#1中的输出需要
"user2";"512";"Built-in account for administering the computer/domain";"False";"False";"user2";"True";"True";"True";"S-1-5-21-3445027559-693823181-3401817782-500";"User";"OK";"23. 1. 2012 9:41:34";"20. 1. 2012 16:01:33";"10";"True";
因为File#1的内容是可变的,所以使用一些正则表达式在我的情况下不起作用。我尝试使用grep
进行查找,但它也没有用。
到目前为止,我试过这个
find file1.txt -type f -exec sed -f patt.regular {} \;
patt.regular
是这样的:
s/10.30.8.204/XX.YY.8.204/g
不幸的是它不起作用,我怀疑,源文件格式file1.txt有一些问题,因为什么都不会发生,但当我删除原始文件(file1.txt)并创建新的,它似乎没关系
sed
是否有可能出现格式问题?
答案 0 :(得分:1)
在shell中,
for line in $(cat file2.txt); do sed -i "s/$(echo $line | cut -d ';' -f 1)/$(echo $line | cut -d ';' -f 2)/g" file1.txt; done
做你想要的。它需要将文件称为file1.txt
和file2.txt
并驻留在当前目录中。
这对sed
中的每一行都有一个file2.txt
。