-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathebi2biotools.py
executable file
·161 lines (147 loc) · 7.69 KB
/
ebi2biotools.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
# coding: utf-8
import json
import logging
import unicodedata
import glob
import argparse
import requests
import pandas as pd
EBI_COLLECTION = "EBI Tools"
EMBOSS_EBI_COLLECTION = "EMBOSS at EBI Tools"
EBI_CREDITS = [
{"name": "Web Production", "typeEntity": "Person", "typeRole": ["Developer"]},
{"name": "EMBL-EBI", "typeEntity": "Institute", "typeRole": ["Provider"]},
{
"typeEntity": "Person",
"typeRole": ["Primary contact"],
"url": "http://www.ebi.ac.uk/support/",
},
{
"email": "[email protected]",
"name": "Web Production",
"typeEntity": "Person",
"typeRole": ["Primary contact"],
},
]
EMBOSS_CREDITS = [{"name": "EMBOSS", "typeEntity": "Person", "typeRole": ["Developer"]}]
EBI_DOCUMENTATIONS = [
{"type": ["Terms of use"], "url": "http://www.ebi.ac.uk/about/terms-of-use"}
]
EBI_LINKS = [{"type": ["Helpdesk"], "url": "http://www.ebi.ac.uk/support/"}]
EBI_OS = ["Linux", "Windows", "Mac"]
EBI_OWNER = "EMBL_EBI"
logging.basicConfig(format='%(asctime)s - %(message)s', level=logging.INFO)
#url ="https://www.ebi.ac.uk/sites/ebi.ac.uk/files/data/resource.json"
url = "https://www.ebi.ac.uk/api/v1/resources-all?source=contentdb"
r = requests.get(url)
BIOTOOLS_CONTENTS = []
BIOTOOLS_BY_HOMEPAGE = {}
def cache_biotools_contents():
for f in glob.glob("../content/data/*/*.biotools.json"):
entry = json.load(open(f))
entry['homepage'] = entry['homepage'].replace('http://','https://')
BIOTOOLS_CONTENTS.append(entry)
BIOTOOLS_BY_HOMEPAGE[entry["homepage"]] = entry
def norm_str(text):
text = text.replace("\n", " ")
text = text.replace("\u2019", " ")
text = " ".join(text.split())
return unicodedata.normalize("NFKD", text.strip())
def process(args):
cache_biotools_contents()
name_filter = args.service
biotools_entries = []
ebi_entries = [e["node"] for e in r.json()["nodes"]]
for ebi_entry in [
e["node"]
for e in r.json()["nodes"]
if name_filter is None or e["node"]["Title"] == name_filter
]:
biotools_entry = {}
biotools_entry["credits"] = EBI_CREDITS.copy()
biotools_entry["collectionID"] = [EBI_COLLECTION]
if ebi_entry["Title"].startswith("EMBOSS "):
ebi_entry["Title"] = ebi_entry["Title"][7:]
biotools_entry["credits"].append(EMBOSS_CREDITS)
biotools_entry["collectionID"].append(EMBOSS_EBI_COLLECTION)
tool_id = f"{ebi_entry['Title']}"
tool_name = f"{ebi_entry['Title']} (EBI)"
biotools_entry["name"] = tool_name
biotools_entry["biotoolsID"] = tool_id
biotools_entry["biotoolsCURIE"] = f"biotools:{tool_id}"
biotools_entry["description"] = norm_str(ebi_entry["Description"])
biotools_entry["documentation"] = EBI_DOCUMENTATIONS.copy()
# TODO tool documentation
biotools_entry["function"] = []
edam_operations = [
{"url": function[5:]}
for function in ebi_entry["Functions"].split(", ")
if function.startswith("edam:")
]
# TODO function inputs and outputs
biotools_entry["function"] = {"operation": edam_operations}
biotools_entry["homepage"] = ebi_entry["URL"].replace('http://','https://')
biotools_entry["links"] = EBI_LINKS.copy()
biotools_entry["operatingSystem"] = EBI_OS.copy()
biotools_entry["owner"] = EBI_OWNER
biotools_entry["ebi_nodeid"] = ebi_entry["Nid"]
#print(json.dumps(biotools_entry, indent=4, sort_keys=True))
match = lookup_in_biotools(biotools_entry)
if match:
biotools_entry["biotoolsID_official"] = match["biotoolsID"]
biotools_entry["maturity"] = match.get("maturity", None)
biotools_entry["biotoolsID_collections"] = match.get("collectionID",[])
logging.info(f"{biotools_entry['name']}, {biotools_entry['homepage']}, ->, {match.get('biotoolsID','')}, {match.get('homepage','')}, {str(match.get('collectionID',''))}")
else:
biotools_entry["biotoolsID_official"] = None
biotools_entry["maturity"] = None
biotools_entry["biotoolsID_collections"] = []
logging.info(f"{biotools_entry['name']}, {biotools_entry['homepage']}, -> NO MATCH")
biotools_entries.append(biotools_entry)
kept_keys = ["biotoolsID", "homepage", "biotoolsID_official", "biotoolsID_collections", "maturity", "ebi_nodeid"]
df_mapped = pd.DataFrame([{ key: bt_entry[key] for key in kept_keys} for bt_entry in biotools_entries])
mapped_ids = [bt["biotoolsID_official"] for bt in biotools_entries if bt["biotoolsID_official"]!=None]
df_nonmapped = pd.DataFrame([("", entry.get("homepage",None), entry["biotoolsID"], entry.get("collectionID",[]), entry.get("maturity", None), entry.get("ebi_nodeid", None)) for entry in BIOTOOLS_CONTENTS if EBI_COLLECTION in entry.get("collectionID",[]) and entry["biotoolsID"] not in mapped_ids])
df_allbiotools = pd.DataFrame([(entry.get("homepage",None), entry["biotoolsID"], entry.get("collectionID",[]), entry.get("maturity", None)) for entry in BIOTOOLS_CONTENTS])
df_nonmapped.columns = kept_keys
logging.info(f"EBI tools: {len(biotools_entries):>5}")
logging.info(f"Bio.tools: {len(BIOTOOLS_CONTENTS):>5}")
logging.info(f"Matched tools: {len([entry for entry in biotools_entries if 'biotoolsID_official' in entry.keys() and entry['biotoolsID_official']!=None]):>5}")
logging.info(f"Matched tools with col: {len([entry for entry in biotools_entries if 'EBI Tools' in entry.get('biotoolsID_collections',[])]):>5}")
logging.info(f"Non-Matched tools with col: {len(df_nonmapped):>5}")
if args.summary_file:
writer = pd.ExcelWriter(args.summary_file)
df_identified = pd.concat([df_mapped, df_nonmapped])
df_identified.rename(columns={"biotoolsID": "EBI", "homepage": "homepage", "biotoolsID_official":"bio.tools", "biotoolsID_collections":"collections"}, inplace=True)
df_identified = df_identified[['ebi_nodeid', 'EBI', 'bio.tools', 'homepage', 'collections', 'maturity']]
df_identified.to_excel(writer, sheet_name="EBI Identified", index=False)
#df_mapped.rename(columns={"biotoolsID": "Canonical bio.tools ID", "homepage": "homepage (in bio.tools; URL in EBI)", "biotoolsID_official":"Current bio.tools ID", "biotoolsID_collections":"collections"}, inplace=True)
#df_mapped.to_excel(writer, sheet_name="EBI Mapped entries", index=False)
#df_nonmapped.rename(columns={"biotoolsID": "Canonical bio.tools ID", "homepage": "homepage (in bio.tools; URL in EBI)", "biotoolsID_official":"Current bio.tools ID", "biotoolsID_collections":"collections"}, inplace=True)
#df_nonmapped.to_excel(writer, sheet_name="EBI Non-mapped entries", index=False)
#df_allbiotools.columns=["homepage (in bio.tools; URL in EBI)","Current bio.tools ID","collections","maturity"]
#df_allbiotools.to_excel(writer, sheet_name="All bio.tools", index=False)
writer.save()
def lookup_in_biotools(query_entry):
if query_entry["homepage"] in BIOTOOLS_BY_HOMEPAGE.keys():
return BIOTOOLS_BY_HOMEPAGE[query_entry["homepage"]]
return None
def main():
parser = argparse.ArgumentParser(prog="ebi2biotools")
parser.set_defaults(func=process)
parser.add_argument(
"--service",
required=False,
default=None,
help="process only one service with the name provided here"
)
parser.add_argument(
"--summary-file",
required=False,
default=None,
help="File to summarize statistics obtained from the mapping"
)
args = parser.parse_args()
args.func(args)
if __name__ == "__main__":
main()