使用awk命令循环查找并修改后输出。
文件1.dat中保存如下数据farfaef=ferAB.CDfefhui=fgyijiAB.CDferhi=AB.CDfarfaef=ferFRE.CDfefhui=fg...
文件1.dat中保存如下数据
farfaef=ferAB.CD
fefhui=fgyijiAB.CD
ferhi=AB.CD
farfaef=ferFRE.CD
fefhui=fgyijiFF.CE
ferhi=FF.CO
文件2.dat中保存了如下数据
AB.CD
FRE.CD
FF.CE
FF.CO
1.dat的这些数据中要把“=”与2.dat中间的数据全部删除了,并且在3.dat输出结果如下。
farfaef=AB.CD
fefhui=AB.CD
ferhi=AB.CD
farfaef=FRE.CD
fefhui=FF.CE
ferhi=FF.CO
(注:元素数据一列,AB.CD数据一列)
个人理解是拿2.dat的每一行,去遍历1.dat,遇到哪一行有2.dat的数据就修改后输出到3.dat 展开
farfaef=ferAB.CD
fefhui=fgyijiAB.CD
ferhi=AB.CD
farfaef=ferFRE.CD
fefhui=fgyijiFF.CE
ferhi=FF.CO
文件2.dat中保存了如下数据
AB.CD
FRE.CD
FF.CE
FF.CO
1.dat的这些数据中要把“=”与2.dat中间的数据全部删除了,并且在3.dat输出结果如下。
farfaef=AB.CD
fefhui=AB.CD
ferhi=AB.CD
farfaef=FRE.CD
fefhui=FF.CE
ferhi=FF.CO
(注:元素数据一列,AB.CD数据一列)
个人理解是拿2.dat的每一行,去遍历1.dat,遇到哪一行有2.dat的数据就修改后输出到3.dat 展开
2个回答
展开全部
问一下,是去掉的部分都是小写字母,而保留的2.dat中的都是大写字母和"."的组合吗;如果是的话,用下面的命令去掉等号后的非大写字母和非“.”的字符就可以了,如下:
awk '{gsub(/=[^A-Z.]*/,"=");print}' 1.dat > 3.dat
要是还是必须用题目上说的要求,再追问吧~
按照题目的要求的话,可以用以下命大悉令实现:
awk -F '=' 埋仿核'NR==FNR{a[$0]}NR!=FNR{for(i in a){if(match($2,i)){print $1"="i;next}}print $0}' 2.dat 1.dat > 3.dat
上面的命令遇到1.dat中的后面部分没有在2.dat中出现的情况则会输出弯掘1.dat中原来的内容。如果不需要输出这些没有被替换的内容,则去掉最后的print即可。
追问
无法输出3.dat
追答
我运行的结果,是可以的,1.dat在最后一行加入了不命中的,最后结果会输入到3.dat,运行结果如下所示:
test$ cat 1.dat
farfaef=ferAB.CD
fefhui=fgyijiAB.CD
ferhi=AB.CD
farfaef=ferFRE.CD
fefhui=fgyijiFF.CE
ferhi=FF.CO
ferhi=awdkwAB.BB
test$ cat 2.dat
AB.CD
FRE.CD
FF.CE
FF.CO
test$ awk -F '=' 'NR==FNR{a[$0]}NR!=FNR{for(i in a){if(match($2,i)){print $1"="i;next}}print}' 2.dat 1.dat > 3.dat
test$ cat 3.dat
farfaef=AB.CD
fefhui=AB.CD
ferhi=AB.CD
farfaef=FRE.CD
fefhui=FF.CE
ferhi=FF.CO
ferhi=awdkwAB.BB
test$
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询