forked from obi-ontology/obi
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathupdate-term-reservations.py
43 lines (35 loc) · 1.09 KB
/
update-term-reservations.py
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
import csv
import logging
from argparse import ArgumentParser, FileType
def main():
parser = ArgumentParser()
parser.add_argument("reservations", type=FileType("r"))
parser.add_argument("obi_terms", type=FileType("r"))
parser.add_argument("output", type=FileType("w"))
args = parser.parse_args()
obi_terms = {}
reader = csv.reader(args.obi_terms, delimiter="\t")
next(reader)
for row in reader:
obi_terms[row[0]] = row[1]
out_rows = []
reader = csv.DictReader(args.reservations, delimiter="\t")
fnames = None
for row in reader:
if not fnames:
fnames = row.keys()
term_id = row["ID"]
term_label = row["label"]
if term_id in obi_terms:
obi_label = obi_terms[term_id]
if term_label != obi_label:
logging.warning(f"Reservation table label ('{term_label}') for {term_id} does not match label in OBI ('{obi_label}')")
row["merged"] = True
else:
row["merged"] = False
out_rows.append(row)
writer = csv.DictWriter(args.output, delimiter="\t", lineterminator="\n", fieldnames=fnames)
writer.writeheader()
writer.writerows(out_rows)
if __name__ == '__main__':
main()