首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python,比较两个文件并得到差异

python,比较两个文件并得到差异
EN

Stack Overflow用户
提问于 2015-02-16 15:34:30
回答 3查看 114关注 0票数 0

我有两个文件,一个是用户输入f1,另一个是数据库f2。我想搜索来自f1的字符串是否在数据库(F2)中。如果不打印那些如果f2不存在的。我的代码有问题,它不能正常工作:这里是f1:

代码语言:javascript
复制
rbs003491
rbs003499
rbs003531
rbs003539
rbs111111

以下是f2:

代码语言:javascript
复制
AHPTUR13,rbs003411 
AHPTUR13,rbs003419 
AHPTUR13,rbs003451 
AHPTUR13,rbs003459 
AHPTUR13,rbs003469 
AHPTUR13,rbs003471 
AHPTUR13,rbs003479 
AHPTUR13,rbs003491 
AHPTUR13,rbs003499 
AHPTUR13,rbs003531 
AHPTUR13,rbs003539 
AHPTUR13,rbs003541 
AHPTUR13,rbs003549 
AHPTUR13,rbs003581 

在这种情况下,它将返回rbs11111,因为它不在f2中。守则是:

代码语言:javascript
复制
 with open(c,'r') as f1:
             s1 = set(x.strip() for x in f1)
             print s1
             with open("/tmp/ARNE/blt",'r') as f2:
                  for line in f2:
                      if line not in s1:
                          print line 
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-02-16 15:40:07

如果您只关心每一行的第二部分(rbs003411来自AHPTUR13,rbs003411):

代码语言:javascript
复制
with open(user_input_path) as f1, open('/tmp/ARNE/blt') as f2:
    not_found = set(f1.read().split())
    for line in f2:
        _, found = line.strip().split(',')
        not_found.discard(found)  # remove found word
    print not_found
    # for x in not_found:
    #     print x
票数 1
EN

Stack Overflow用户

发布于 2015-02-16 15:38:41

for循环中的line变量将包含类似于"AHPTUR13,rbs003411“的内容,但您只对第二部分感兴趣。你应该做这样的事情:

代码语言:javascript
复制
for line in f2:
    line = line.strip().split(",")[1]
    if line not in s1:
        print line
票数 0
EN

Stack Overflow用户

发布于 2015-02-16 15:38:51

您需要检查行的最后一部分,而不是所有行,您可以将行从f2与,拆分,然后选择最后一部分(x.strip().split(',')[-1]),如果要搜索来自f1的字符串是否在数据库(F2)中,这里的逻辑是错误的,您需要从f2创建您的集合:

代码语言:javascript
复制
with open(c,'r') as f1,open("/tmp/ARNE/blt",'r') as f2:

                  s1 = set(x.strip().split(',')[-1] for x in f2)
                  print s1
                  for line in f1:
                      if line.strip() not in s1:
                          print line
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28544921

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档