python中实现txt文档的去除不符合条件的行(即去掉1.txt中和2.txt有一定条件的行),高分悬赏,不胜感激

其实是大型数据,这里只是举例。例如:第一个1.txt文档为:abcde00dldf4dkfdf00djfj6dkkdf12djkf5dffdh12dkff6dkdfo第二... 其实是大型数据,这里只是举例。
例如:
第一个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中,请问问题在哪里?或者说另外写程序帮我实现该功能,不胜感激!
展开
 我来答
lejoylejoy
2012-08-16 · TA获得超过1003个赞
知道小有建树答主
回答量:513
采纳率:75%
帮助的人:448万
展开全部
内嵌的那个for循环有问题。。。
fp2= open('E:/2.txt','r')
这个fp2貌似只能循环一次,也就是每次循环fp1的时候,fp2并不会完完整整的从头循环一次。
比如:第一次遍历fp1时,内嵌的fp2的for循环 遍历到第二行时,break了。然后fp1遍历下一行时,fp2就直接从第三行开始遍历了。

简而言之,可以理解为:fp2每遍历完一行,就直接删除了这一行
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式