Skip to main content

Parse FHIR query string

Project description

A library to parse FHIR query strings.

  • Validates type and returns correct object

  • Built-in search parameters from FHIR standard

  • Supports modifiers, prefixes, and chains

Generally only have included relevant Resources with maturity greater than 2. Some exceptions.

Usage

from fhir_parse_qs import Search

# supported endpoints
Search.supported --> [...]

# simple use
search = Search('Patient', 'name=bob') # Search(<endpoint>, <query_string>)

# endpoint
search.endpoint --> 'Patient'

# all the namedtuples
search.parsed --> [FHIRSearch(...)]

# index as key; each parameter/value pair gets parsed into a namedtuple
search[0] --> FHIRSearch(...)
search[0].modifier --> None
search[0].prefix --> None
search[0].value --> 'bob'
search[0].parameter --> 'name'
search[0].type_ --> 'string'
search[0].chain --> None

# act like dict with parameter as key
search['name'] --> FHIRSearch(...) #list if non-unique parameter

# can iterate over the parameter/value pairs
for x in search:
     print(x) --> FHIRSearch(...)

# unrecognized parameter, ignore and log it
search = Search('Patient', 'random=test')
search.error --> [...]

# chains - namedtuple with endpoint, target_parameter, target_type
search = Search('Observation', 'patient.name=peter')
search[0].parameter --> 'name' # last parameter in chain
search[0].value --> 'peter'
search[0].chain --> [FHIRChain(...), FHIRChain(...)]
search[0].chain[0].endpoint = 'Observation'
search[0].chain[0].target = 'patient'
search[0].chain[0].ttype = 'reference'
search[0].chain[1].endpoint = 'Patient'
search[0].chain[1].target = 'name'
search[0].chain[1].ttype = 'string'

# return control parameters (eg, _sort, _count, etc)
search.control --> [...]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fhir_parse_qs-0.4.0.tar.gz (2.8 kB view details)

Uploaded Source

Built Distribution

fhir_parse_qs-0.4.0-py2.py3-none-any.whl (2.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file fhir_parse_qs-0.4.0.tar.gz.

File metadata

  • Download URL: fhir_parse_qs-0.4.0.tar.gz
  • Upload date:
  • Size: 2.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.7.0

File hashes

Hashes for fhir_parse_qs-0.4.0.tar.gz
Algorithm Hash digest
SHA256 5ac2073ae381e3e1f56081bcdee42306162840c81af74e58d4fd4535654981c6
MD5 d4ef46b70b10826571f08dca299340da
BLAKE2b-256 fdee731d1febe00d05341a79102e15998ca10b750a3275ff0316f345df2c86d6

See more details on using hashes here.

Provenance

File details

Details for the file fhir_parse_qs-0.4.0-py2.py3-none-any.whl.

File metadata

  • Download URL: fhir_parse_qs-0.4.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 2.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.7.0

File hashes

Hashes for fhir_parse_qs-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 62ce29e93ee30fedc2791810cadaa760bfe1b9acf2795454f7a9b3e5579cbeaf
MD5 df382cb08a4fe10a1967783deac20055
BLAKE2b-256 876b8c10f313f5cd393ea48321d95def99e650e3e8ea529b01950db79d128c09

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page