Skip to main content

A datetime-compatible class for FHIR date/datetime values.

Project description

Documentation Status https://img.shields.io/pypi/v/fhirdatetime.svg https://travis-ci.com/mmabey/fhirdatetime.svg?branch=main https://coveralls.io/repos/github/mmabey/fhirdatetime/badge.svg?branch=main https://img.shields.io/badge/code%20style-black-000000.svg

A datetime-compatible class for FHIR date/datetime values.

The FHIR specification from HL7 is “a standard for health care data exchange.” The FHIR spec includes date and datetime data types that provide more flexibility than the standard Python date and datetime types. This makes sense when you consider a patient may report to their provider that they have experience a particular symptom since a particular year without knowing the month or day of onset.

Installation

Install fhirdatetime using pip:

pip install fhirdatetime

Usage

Creation

The fhirdatetime.FhirDateTime class is designed to be used to store date/datetime values from FHIR payloads (which are JSON strings), you can create instances from str values:

>>> FhirDateTime("2021-03-15")
fhirdatetime.FhirDateTime(2021, 3, 15)

You can also convert native date and datetime objects directly:

>>> FhirDateTime(date(2021, 3, 15))
fhirdatetime.FhirDateTime(2021, 3, 15)
>>> FhirDateTime(datetime(2021, 3, 15, 20, 54))
fhirdatetime.FhirDateTime(2021, 3, 15, 20, 54)

One purpose of this library is to allow flexibility in granularity without sacrificing the ability to compare (using <, >, ==, etc.) against objects of the same type as well as native date and datetime objects.

Comparison

When comparing objects, only the values that are populated for both objects are considered. Consider the following examples in which only the years are compared:

>>> FhirDateTime(2021) == FhirDateTime(2021, 3, 15)
True
>>> FhirDateTime(2021) == datetime(2021, 3, 15, 23, 56)
True
>>> FhirDateTime(2021) == date(2021, 3, 15)
True
>>> FhirDateTime(2021) < FhirDateTime(2021, 3, 15)
False
>>> FhirDateTime(2021) > FhirDateTime(2021, 3, 15)
False

Sorting

When you need to sort a sequence of either FhirDateTime objects or object that contain a FhirDateTime object, the FhirDateTime.sort_key() function will make it easier to sort the items properly.

There are two ways to use this function. The first is intended for use when sorting a sequence of FhirDateTime objects, something like this (notice that sort_key() is called with no parameters):

>>> sorted(
...     [FhirDateTime(2021, 4), FhirDateTime(2021), FhirDateTime(2021, 4, 12)],
...     key=FhirDateTime.sort_key()
... )
[FhirDateTime(2021), FhirDateTime(2021, 4), FhirDateTime(2021, 4, 12)]

The second is for use when sorting a sequence of objects that have FhirDateTime objects as attributes. This example sorts the CarePlan [1] objects by the care plan’s period’s start date:

>>> sorted(care_plan_list, key=FhirDateTime.sort_key("period.start"))

In this example, sorted() passes each item in care_plan_list to the sort_key static method, which first gets the period attribute of the item, then gets the start attribute of the period. Finally, the year, month, day, and other values are returned to sorted(), which does the appropriate sorting on those values.

If neither of these use cases of the sort_key() function apply to what you need to do, you can always use a custom lambda to do your sorting. For example, the following is equivalent to the care plan sorting example:

>>> sorted(care_plan_list, key=lambda x: FhirDateTime.sort_key(x.period.start))

License

This project is licensed under the MIT license.


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

fhirdatetime-0.1.0b8.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

fhirdatetime-0.1.0b8-py3-none-any.whl (18.7 kB view details)

Uploaded Python 3

File details

Details for the file fhirdatetime-0.1.0b8.tar.gz.

File metadata

  • Download URL: fhirdatetime-0.1.0b8.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.9.1 Linux/4.15.0-1077-gcp

File hashes

Hashes for fhirdatetime-0.1.0b8.tar.gz
Algorithm Hash digest
SHA256 1d2b8e608256ca7452e89cae805bb26e9091b19473c311165935ca73a8647292
MD5 e50643f805a2523afeb4d24064f008ea
BLAKE2b-256 48c3550fc3011e6a31359043d2f79eb5e528d0e2d287d210bbc446c7a9652172

See more details on using hashes here.

File details

Details for the file fhirdatetime-0.1.0b8-py3-none-any.whl.

File metadata

  • Download URL: fhirdatetime-0.1.0b8-py3-none-any.whl
  • Upload date:
  • Size: 18.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.9.1 Linux/4.15.0-1077-gcp

File hashes

Hashes for fhirdatetime-0.1.0b8-py3-none-any.whl
Algorithm Hash digest
SHA256 c8ece6726b9e75418f1037f9dcda8906346bfb0f133a9748bf3fe1c915374af5
MD5 bea4bf11c8fe3d9bf1008c33ff0abfc6
BLAKE2b-256 371a1badfe1abf1aaf47ca51446ec1fb22f415a0c5e7ff860c2565e9b0447ff3

See more details on using hashes here.

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