aboutsummaryrefslogtreecommitdiffstats
path: root/sdvx/eamuse_csv/eamuse_merge_csv.py
blob: 7ff4ad9afd06f0993b8b41d769c06523748f8958 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import argparse
import csv
import os

def merge_csv(old_file: str, new_file: str, output_file: str):
    old_csv_set = set()
    new_csv_set = set()
    encoding = "utf-8"
    with open(old_file, encoding=encoding) as old_csv:
        reader = csv.reader(old_csv, delimiter=",")
        [old_csv_set.add(tuple(row)) for row in reader]
        with open(new_file, "r", encoding=encoding) as new_csv:
            reader = csv.reader(new_csv, delimiter=",")
            header = next(reader)
            [new_csv_set.add(tuple(row)) for row in reader]
            new_csv_set = new_csv_set - old_csv_set

        with open(output_file, "w", encoding=encoding, newline="") as new_csv:
            writer = csv.writer(new_csv, delimiter=",")
            writer.writerow(header)
            for row in new_csv_set:
                if row == ():
                    continue
                writer.writerow(list(row))

        print("Done! Your newly merged CSV is at " + output_file)
        print("Do you want to delete the old file, and create a new old.csv? (y/n)")
        action = input()
        if not action == "y":
            print("OK. Exiting")
            exit(0)
        print("Renaming " + new_file + " to old.csv and deleting " + old_file + "...")
        os.remove(old_file)
        os.rename(new_file, "old.csv")


if __name__ == "__main__":
    parser = argparse.ArgumentParser(
        prog="eamuse_merge_to_csv",
        description="Merges an old SDVX e-amuse CSV with a new one. Keeping only new scores in the new file",
    )
    parser.add_argument("--old", help="Old CSV file", required=True)
    parser.add_argument("--new", help="New CSV file", required=True)
    parser.add_argument("--output", help="Output File", default="sdvx_merged.csv")
    args = parser.parse_args()
    merge_csv(args.old, args.new, args.output)
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage