Compare 2 seperate csv files and write difference to a new csv file - Python 2.7

后端 未结 3 1242
南旧
南旧 2021-01-26 05:21

I am trying to compare two csv files in python and save the difference to a third csv file in python 2.7.

import csv

f1 = open (\"olddata/file1.csv\")
oldFile1         


        
相关标签:
3条回答
  • 2021-01-26 05:52

    The error is correct: tuple has no "difference" method.

    I guess you want to use set (and make the elements immutable)?

    set1 = set([tuple(item) for item in oldList1])
    set2 = set([tuple(item) for item in oldList2])
    
    0 讨论(0)
  • 2021-01-26 06:07

    What do you mean by difference? The answer to that gives you two distinct possibilities.

    If a row is considered same when all columns are same, then you can get your answer via the following code:

    import csv
    
    f1 = open ("olddata/file1.csv")
    oldFile1 = csv.reader(f1)
    oldList1 = []
    for row in oldFile1:
        oldList1.append(row)
    
    f2 = open ("newdata/file2.csv")
    oldFile2 = csv.reader(f2)
    oldList2 = []
    for row in oldFile2:
        oldList2.append(row)
    
    f1.close()
    f2.close()
    
    print [row for row in oldList1 if row not in oldList2]
    

    However, if two rows are same if a certain key field (i.e. column) is same, then the following code will give you your answer:

    import csv
    
    f1 = open ("olddata/file1.csv")
    oldFile1 = csv.reader(f1)
    oldList1 = []
    for row in oldFile1:
        oldList1.append(row)
    
    f2 = open ("newdata/file2.csv")
    oldFile2 = csv.reader(f2)
    oldList2 = []
    for row in oldFile2:
        oldList2.append(row)
    
    f1.close()
    f2.close()
    
    keyfield = 0 # Change this for choosing the column number
    
    oldList2keys = [row[keyfield] for row in oldList2]
    print [row for row in oldList1 if row[keyfield] not in oldList2keys]
    

    Note: The above code might run slow for extremely large files. If instead, you wish to speed up code through hashing, you can use set after converting the oldLists using the following code:

    set1 = set(tuple(row) for row in oldList1)
    set2 = set(tuple(row) for row in oldList2)
    

    After this, you can use set1.difference(set2)

    0 讨论(0)
  • 2021-01-26 06:15
    import csv
    
    def read_csv_file(filename):
        res = []
        with open(filename) as f:
             for line in csv.reader(f):
                   res.append(line)
    
    
    oldList1 = read_csv_file("olddata/file1.csv")
    oldList2 = read_csv_file("olddata/file2.csv")
    
    
    difference_list = []
    
    for a,b in zip(oldList1,oldList2):
       if a != b:
           difference_list.append(a + '\t' + b)
    

    Eventually you have a list of items and you can just write them to file.

    EDIT: In this situation, [a,b,c] vs [b,c,a] will fail. If you know that [a,b,c] vs [b,c,a] should return no difference, use the following code pls.

    import csv
    
    def read_csv_file(filename):
        res = []
        with open(filename) as f:
             for line in csv.reader(f):
                   res.append(line)
    
    
    oldList1 = read_csv_file("olddata/file1.csv")
    oldList2 = read_csv_file("olddata/file2.csv")
    
    
    difference_list = []
    
    for a in oldList1:
      for b in oldList2:
        if a != b:
           difference_list.append(a + '\t' + b)
    
    0 讨论(0)
提交回复
热议问题