forked from OBOFoundry/OBOFoundry.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake-shacl-prefixes.py
executable file
·55 lines (39 loc) · 1.72 KB
/
make-shacl-prefixes.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
44
45
46
47
48
49
50
51
52
53
54
55
#!/usr/bin/env python3
import csv
import sys
import yaml
from argparse import ArgumentParser
def main(args):
"""
Takes ontologies.yml file and makes a triple file with SHACL prefixes.
For example, for uberon it will generate:
[ sh:prefix "UBERON" ; sh:namespace "http://purl.obolibrary.org/obo/UBERON_"]
We always assume the CURIE prefix is uppercase, unless 'preferred_prefix' is specified
(for mixed-case prefixes, e.g. FBbt)
This can be useful for converting an OBO class PURL to a prefix without assumption-embedding string conversions.
It can be used to interconvert PURLs to CURIEs.
Note that while prefixes can sometimes be seen in RDF files, this is part of the syntax and not part of the data,
the prefixes are expanded at parse time. The obo_prefixes.ttl file makes these explicit.
We use the SHACL vocabulary since it provides convenient predicates for putting prefixes in the domain of discourse;
however, it does not entail any use of SHACL
"""
parser = ArgumentParser(description='''
Takes ontologies.yml file and makes a triple file with shacl prefixes''')
parser.add_argument('input')
args = parser.parse_args()
stream = open(args.input, 'r')
data = yaml.load(stream, Loader=yaml.SafeLoader)
print('@prefix sh: <http://www.w3.org/ns/shacl#> .')
print('@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .')
print('[')
print(' sh:declare')
sep = ''
for ont in data['ontologies']:
if ont.get('is_obsolete',False):
continue
prefix = ont.get('preferredPrefix', ont['id'].upper())
print(f'{sep}[ sh:prefix "{prefix}" ; sh:namespace "http://purl.obolibrary.org/obo/{prefix}_"]')
sep = ','
print('] .')
if __name__ == '__main__':
main(sys.argv)