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中,请问问题在哪里?或者说另外写程序帮我实现该功能,不胜感激! 展开
例如:
第一个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中,请问问题在哪里?或者说另外写程序帮我实现该功能,不胜感激! 展开
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询