aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArun Isaac2022-10-30 20:54:01 +0530
committerArun Isaac2022-10-30 23:58:38 +0530
commit1a56fb7c066a6813b3e3e851832327c8e48c4952 (patch)
tree8de4ee61aa7b8eb7315c0c3948ef6f880e3dffa0
parent25f9279b0078ef0cc93507776c9c8413a0a73a00 (diff)
downloadgn-transform-databases-1a56fb7c066a6813b3e3e851832327c8e48c4952.tar.gz
Import GeneRIF data into RDF.
* import-generif.scm: New file.
-rwxr-xr-ximport-generif.scm74
1 files changed, 74 insertions, 0 deletions
diff --git a/import-generif.scm b/import-generif.scm
new file mode 100755
index 0000000..69a5f78
--- /dev/null
+++ b/import-generif.scm
@@ -0,0 +1,74 @@
+#! /usr/bin/env guile
+!#
+
+;; This script imports GeneRIF data downloaded from
+;; https://ftp.ncbi.nih.gov/gene/GeneRIF/generifs_basic.gz into RDF.
+
+(use-modules (rnrs io ports)
+ (srfi srfi-26)
+ (srfi srfi-171)
+ (ice-9 match)
+ (ice-9 regex)
+ (dump triples)
+ (dump utils)
+ (zlib))
+
+(define decode-html-entities
+ (cut regexp-substitute/global
+ #f
+ ;; We tolerate the absence of the trailing semicolon.
+ "&#([[:digit:]]+);{0,1}"
+ <>
+ 'pre
+ (compose string integer->char string->number (cut match:substring <> 1))
+ 'post))
+
+(define (main generif-data-file dump-directory)
+ (with-output-to-file (string-append dump-directory "/generif.ttl")
+ (lambda ()
+ (prefix "rdf:" "<http://www.w3.org/1999/02/22-rdf-syntax-ns#>")
+ (prefix "rdfs:" "<http://www.w3.org/2000/01/rdf-schema#>")
+ (prefix "gn:" "<http://genenetwork.org/>")
+ (newline)
+ ;; TODO: Link to gene objects, not merely literal Gene IDs.
+ (triple 'gn:geneId 'rdfs:domain 'gn:geneRIF)
+ (triple 'gn:geneId 'rdfs:range 'rdfs:Literal)
+ ;; TODO: Link to gn:publication objects, not merely literal
+ ;; PubMed IDs.
+ (triple 'gn:geneRIFEvidencedByPubMedId 'rdfs:domain 'gn:geneRIF)
+ (triple 'gn:geneRIFEvidencedByPubMedId 'rdfs:range 'rdfs:Literal)
+ (triple 'gn:geneRIFText 'rdfs:domain 'gn:geneRIF)
+ (triple 'gn:geneRIFText 'rdfs:range 'rdfs:Literal)
+
+ (call-with-gzip-input-port (open-input-file generif-data-file)
+ (lambda (port)
+ ;; Read and discard header.
+ (get-line port)
+ ;; Dump other lines.
+ (port-transduce
+ (compose (tenumerate)
+ (tmap (match-lambda
+ ;; Is there a better way to identify
+ ;; GeneRIF entries instead of merely
+ ;; enumerating them?
+ ((i . line)
+ (match (string-split line #\tab)
+ ((_ gene-id pubmed-id _ text)
+ (scm->triples
+ `((rdf:type . gn:geneRIF)
+ (gn:geneId . ,(string->number gene-id))
+ (gn:pubMedId . ,(string->number pubmed-id))
+ ;; Some text has HTML
+ ;; entities. Decode them.
+ (gn:geneRIFText . ,(decode-html-entities text)))
+ (string->identifier "geneRIF" (number->string i)))))))))
+ (const #t)
+ get-line
+ port))))))
+
+(match (command-line)
+ ((arg0 generif-data-file dump-directory)
+ (main generif-data-file dump-directory))
+ ((arg0 _ ...)
+ (format (current-error-port) "Usage: ~a GENERIF-DATA-FILE DUMP-DIRECTORY~%" arg0)
+ (exit #f)))