用python代码实现txt文档的去除不符合条件的行(即去掉1.txt中和2.txt有一定条件的行)

其实是大型数据,这里只是举例。
例如:
第一个1.txt文档为:
a b c d e
00 dldf 4 dkf df
00 djfj 6 dkk df
12 djkf 5 dff dh
12 dkff 6 dkd fo
第二个2.txt文档为:
a b c d e
00 dldf 4 sms df
12 dkff 6 fgh fo
判断条件为1.txt中的每行字符串str1与2.txt中每行字符串str2,如果有str1[0]==str2[0] and str1[2]==str2[2],也就去掉1.txt中的该行,如上面示例,输出结果保存为另一3.txt文档应该为(需要保留第一行标题行):
a b c d e
00 djfj 6 dkk df
12 djkf 5 dff dh
我暂时用的代码为:
import sys
import os
import string
fp1= open('E:/1.txt','r')
fp2= open('E:/2.txt','r')
fp3= open('E:/3.txt','a+')
#读取文件首行,无需处理
str1 = fp1.readline()
fp3.write(str1)
for oneLine in fp1 :
str1= oneLine.split()
t=1
for PLine in fp2 :
str2= PLine.split()
if ((str1[0]==str2[0])and (str1[2]==str2[2])) :
t=0
break
if (t==1):
fp3.write(' '.join(str1)+'\n')
fp1.close()
fp2.close()
fp3.close()
但是输出结果却没有去掉任何行,而是将原行全部输出到3.txt中,请问问题在哪里?或者说另外写程序帮我实现该功能,不胜感激!

import sys
import os
import string
fp1= open('1.txt','r')
fp2= open('2.txt','r')
fp3= open('3.txt','a+')
#读取文件首行,无需处理
str1=fp1.readline()
fp2.readline()
fp3.write(str1)
for oneLine in fp1 :
str1= oneLine.split()
t=1
fp2.seek(0)
for PLine in fp2 :
str2= PLine.split()
if ((str1[0]==str2[0])and (str1[2]==str2[2])) :
t=0
break
if (t==1):
fp3.write(' '.join(str1)+'\n')
fp1.close()
fp2.close()
fp3.close()
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-08-16
import sys
import os
import string
fp1= open('E:/1.txt','r')
fp3= open('E:/3.txt','a+')
#读取文件首行,无需处理
str1 = fp1.readline()
fp3.write(str1)
for oneLine in fp1:
str1= oneLine.split()
t=1
fp2= open('E:/2.txt','r')#*******************************
for PLine in fp2:
str2= PLine.split()
if str1[0]==str2[0] and str1[2]==str2[2]:
t=0
break
if t==1:
fp3.write(' '.join(str1)+'\n')
fp2.close()#**********************
fp1.close()
fp3.close()
相似回答