This library holds FHIR support code for the Cumulus project as a whole.
pip install cumulus-fhir-support
Lists available multiline JSON files in the target directory (allowing filtering by FHIR resource).
import cumulus_fhir_support
cumulus_fhir_support.list_multiline_json_in_dir("/")
# {
# "/con1.ndjson": "Condition",
# "/pat1.jsonl": "Patient",
# "/random.jsonl": None,
# }
cumulus_fhir_support.list_multiline_json_in_dir("/", "Patient")
# {
# "/pat1.jsonl": "Patient",
# }
cumulus_fhir_support.list_multiline_json_in_dir("/", ["Condition", "Patient"])
# {
# "/con1.ndjson": "Condition",
# "/pat1.jsonl": "Patient",
# }
cumulus_fhir_support.list_multiline_json_in_dir("/does-not-exist/")
# {}
cumulus_fhir_support.list_multiline_json_in_dir("s3://mybucket/", fsspec_fs=s3_fs)
# {
# "/mybucket/procs.ndjson": "Procedure",
# }
Iterates over a single multiline JSON file.
import cumulus_fhir_support
list(cumulus_fhir_support.read_multiline_json("/pat1.jsonl"))
# [
# {"resourceType": "Patient", "id": "pat1", "birthDate": "2020-10-16"},
# {"resourceType": "Patient", "id": "pat2", "birthDate": "2013-04-18"},
# ]
list(cumulus_fhir_support.read_multiline_json("/does-not-exist.ndjson"))
# []
list(cumulus_fhir_support.read_multiline_json("/mybucket/procs.ndjson", fsspec_fs=s3_fs))
# [
# {"resourceType": "Procedure", "id": "proc1", "status": "stopped"},
# ]
Iterates over every JSON object in a directory (allowing filtering by FHIR resource).
import cumulus_fhir_support
list(cumulus_fhir_support.read_multiline_json_from_dir("/"))
# [
# {"resourceType": "Condition", "id": "con1", "onsetDateTime": "2011-11-24"},
# {"resourceType": "Patient", "id": "pat1", "birthDate": "2020-10-16"},
# {"resourceType": "Patient", "id": "pat2", "birthDate": "2013-04-18"},
# {"description": "not a fhir object"},
# ]
list(cumulus_fhir_support.read_multiline_json_from_dir("/", "Condition"))
# [
# {"resourceType": "Condition", "id": "con1", "onsetDateTime": "2011-11-24"},
# ]
list(cumulus_fhir_support.read_multiline_json_from_dir("/", ["Condition", "Patient"]))
# [
# {"resourceType": "Condition", "id": "con1", "onsetDateTime": "2011-11-24"},
# {"resourceType": "Patient", "id": "pat1", "birthDate": "2020-10-16"},
# {"resourceType": "Patient", "id": "pat2", "birthDate": "2013-04-18"},
# ]
list(cumulus_fhir_support.read_multiline_json_from_dir("/does-not-exist/"))
# []
list(cumulus_fhir_support.read_multiline_json_from_dir("/mybucket/", fsspec_fs=s3_fs))
# [
# {"resourceType": "Procedure", "id": "proc1", "status": "stopped"},
# ]
Calculates a schema that can cover a given collection of FHIR objects.
import cumulus_fhir_support
rows = [
{
"resourceType": "Patient",
"id": "1",
"extension": [{
"url": "http://hl7.org/fhir/us/core/StructureDefinition/us-core-ethnicity",
"extension": [{
"url": "ombCategory",
"valueCoding": {
"code": "2135-2",
"display": "Hispanic or Latino",
"system": "urn:oid:2.16.840.1.113883.6.238",
},
}],
}],
},
]
# The resulting schema will be both wide (every toplevel column)
# and deep enough for every field in `rows`.
# That is, both the non-present toplevel field "telecom" and the deeper
# field "extension.extension.valueCoding.system" will be in the schema.
schema = cumulus_fhir_support.pyarrow_schema_from_rows("Patient", rows)