使用其他文件中的模式替换文件中的字符串

时间:2015-05-11 08:40:39

标签: regex replace grep anonymize

我需要使用带有模式的其他文件(如字符串数据库)替换许多文件中的许多字符串。它用于匿名化文件。

示例:

文件#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是否有可能出现格式问题?

1 个答案:

答案 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.txtfile2.txt并驻留在当前目录中。

这对sed中的每一行都有一个file2.txt