-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconvert_json_to_tsv.py
43 lines (32 loc) · 1.49 KB
/
convert_json_to_tsv.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 argparse
import csv
import json
def main():
parser = argparse.ArgumentParser(description='A script that converts the JSON metadata from GISAID to a TSV file.')
required_args = parser.add_argument_group('required arguments')
required_args.add_argument('-j', '--json', type=str, required=True, help='location of given GISAID json file')
required_args.add_argument('-t', '--tsv', type=str, required=True, help='location of resulting TSV file')
args = parser.parse_args()
create_tsv(args.json, args.tsv)
def create_tsv(json_path, tsv_path):
print('Starting conversion...')
error_count = 0
with open(json_path, 'r', encoding='utf-8') as json_file:
with open(tsv_path, 'w') as tsv_file:
for i, line in enumerate(json_file):
# Read one key-value object per line
obj = json.loads(line)
# For first object, take keys as header for TSV
if i == 0:
dw = csv.DictWriter(tsv_file, obj.keys(), delimiter='\t')
dw.writeheader()
try:
# For each object, append its values as new row to TSV
dw.writerow(obj)
except UnicodeEncodeError:
# If UnicodeEncodeError occurs, count and ignore row
error_count += 1
continue
print(f'Finished conversion. {error_count} UnicodeEncodeErrors have occured.')
if __name__ == '__main__':
main()