forked from openMetadataInitiative/openMINDS_SANDS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.py
35 lines (28 loc) · 1.09 KB
/
script.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
import os
import json
input_dir = 'instances/atlas/parcellationEntityVersion/JBA-v2-9'
output_dir = 'instances/atlas/parcellationEntity/JBA'
def main():
existing_dict = {}
def get_existing(pev_filename: str):
jba_version, space, areaname, version, hemisphere = pev_filename.split('_')
if areaname not in existing_dict:
with open(f'{output_dir}/JBA_{areaname}.jsonld', 'r') as fp:
existing_dict[areaname] = json.load(fp)
return existing_dict[areaname]
input_files = os.listdir(input_dir)
output_files = os.listdir(output_dir)
for file in input_files:
with open(f'{input_dir}/{file}', 'r') as fp:
id = json.load(fp).get('@id')
out = get_existing(file)
has_version = out.get('hasVersion') or []
out['hasVersion'] = [
*has_version,
{ '@id': id }]
for key, value in existing_dict.items():
with open(f'{output_dir}/JBA_{key}.jsonld', 'w') as fp:
json.dump(value, fp=fp, indent=4)
fp.write('\n')
if __name__ == "__main__":
main()