From fa2ce410d4730b136f24555c049cef3d6dac1102 Mon Sep 17 00:00:00 2001 From: Munyoki Kilyungi Date: Thu, 8 Jun 2023 14:44:38 +0300 Subject: Fetch phenotypes from virtuoso * gn3/api/metadata.py: Import get_phenotype_metadata. (phenotype): New end-point. * gn3/db/rdf.py (get_phenotype_metadata): New function. Signed-off-by: Munyoki Kilyungi --- gn3/db/rdf.py | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) (limited to 'gn3/db') diff --git a/gn3/db/rdf.py b/gn3/db/rdf.py index e92ccdb..0e472ce 100644 --- a/gn3/db/rdf.py +++ b/gn3/db/rdf.py @@ -26,6 +26,7 @@ PREFIX ncbiTaxon: PREFIX xsd: PREFIX publication: +PREFIX phenotype: """ @@ -198,12 +199,48 @@ CONSTRUCT { return response +def get_phenotype_metadata( + sparql_conn: SPARQLWrapper, name: str ): + """Return info about a phenotype with a given NAME""" __metadata_query = """ +$prefix +CONSTRUCT { + ?phenotype ?pPredicate ?pValue . + ?phenotype ?publicationTerm ?publicationValue . + ?phenotype gn:speciesName ?speciesName . + ?phenotype gn:inbredSetName ?inbredSetBinomialName . + ?phenotype gn:datasetName ?datasetFullName . +} WHERE { + ?phenotype ?pPredicate ?pValue . + OPTIONAL { + ?phenotype gn:phenotypeOfPublication ?publication . + ?publication ?publicationTerm ?publicationValue . + } . + OPTIONAL { + ?phenotype gn:phenotypeOfDataset ?dataset . + ?dataset gn:name ?datasetFullName . + ?dataset gn:datasetOfInbredSet ?inbredSet . + ?inbredSet gn:binomialName ?inbredSetBinomialName . + ?inbredSet gn:inbredSetOfSpecies ?species . + ?species gn:displayName ?speciesName . + } . + FILTER( ?phenotype = phenotype:$name ) . + MINUS { + ?phenotype rdf:type ?pValue . + } + MINUS { + ?publication rdf:type ?publicationValue . + } } """ result: MonadicDict = MonadicDict() + for key, value in sparql_query( sparql_conn, Template(__metadata_query) + .substitute(name=name, + prefix=RDF_PREFIXES) + )[0].items(): + result[key] = value return result -- cgit v1.2.3