Python implementation of the openEHR (R) standard
Project description
pyehr - a Python implementation of the openEHR® standard
pyehr (on pypi, pyehr-openehr) is an open source Python implementation of the openEHR® specification from the ground up in pure Python.
⚠️ Warning: pyehr is under active development and no stable release is available. Though some parts of the core are stable enough, both client and server are liable to change substantially.
pyehr is formed of three parts:
- core - implementation of object model of BASE, RM, AM, etc. in Python
- client - used for interacting with OpenEHR REST API servers
- server - basic Flask-based implementation of the server standard
pyehr.core
pyehr provides an implementation of the following parts of the specification which are used by both the client and the server, and many users may wish to use in a standalone manner.
Features:
- Work in the RM natively in Python with validation of invariants
text = DVText(
value="Hello, world!",
language=CodePhrase(
terminology_id=TerminologyID("ISO_639-1"),
code_string="en-gb",
preferred_term="English (United Kingdom)"
)
)
- Serialise all classes to spec-compliant JSON (with '_type' markers)
print(json.dumps(text.as_json(), indent=1))
{
"_type": "DV_TEXT",
"value": "Hello, world!",
"language": {
"_type": "CODE_PHRASE",
"terminology_id": {
"_type": "TERMINOLOGY_ID",
"value": "ISO_639-1"
},
"code_string": "en-gb",
"preferred_term": "English (United Kingdom)"
}
}
- Use methods as described in the spec across classes
from pyehr.core.rm.data_types.quantity.date_time import DVDate, DVDuration
start_date = DVDate("2026-05-07")
duration = DVDuration("P1Y2M6D")
new_date = start_date + duration
print(str(new_date))
Support level
| Specification part | Status |
|---|---|
| Base model (BASE) | ✅ Complete |
| Reference model (RM) | ✅ Complete (aside from rm.extract and rm.integration) |
| Implementation technology (ITS) - JSON | ✅ Serialisation and deserialisation complete and stable for all implemented classes |
| Archetype model (AOM v1.4 and OPT v1.4) | 🟠 Partial implementation for serialisation/deserialisation but methods unimplemented |
| Implementation technology (ITS) - XML | 🟠 Some support for parsing AOM v1.4 archetypes and templates, limited support elsewhere |
| Archetype model (AOM v2) | ❌ Unsupported |
| Archetype model (ADL v1.4 or ADL v2) | ❌ Unsupported |
pyehr.client
pyehr provides both a transactional REST API client as well as a more sophisticated client for working more easily with versioned objects.
Features:
- Transactional clients for /ehr and /demographic endpoints.
from pyehr.client.ehr import OpenEHREHRRestClient, OpenEHRRestClientResponse
client = OpenEHREHRRestClient(
base_url="https://sandbox.ehrbase.org/ehrbase/rest/openehr/v1"
)
response : OpenEHRRestClientResponse = client.ehr.create_ehr()
print(response.pyehr_obj[0].as_json())
- More object-oriented client for working with versioned objects more natively
from pyehr.client.change_control import VersionedStoreClient
store = VersionedStoreClient(
base_url="http://localhost:5000"
)
p1 = ...
log.info("Create PERSON in store")
object_version_id, contribution, versioned_object = store.create(
obj=p1,
owner_id=ObjectRef("local", "EHR", GenericID("null", "null")),
committer=PartySelf(),
lifecycle_state=VersionLifecycleState.INCOMPLETE
)
pyehr.server
pyehr provides an under-development Flask-based server with accompanying database and authentication backends.
Disclaimer
openEHR® is the registered trademark of the openEHR Foundation and is used with the permission of openEHR International. Use of the trademark does not constitute endorsement of this product by openEHR International or openEHR Foundation.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyehr_openehr-0.0.6.tar.gz.
File metadata
- Download URL: pyehr_openehr-0.0.6.tar.gz
- Upload date:
- Size: 318.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
661a581f80d150ea184bd4a348b0e1aeb36e92ccfc9f48a69ee7f8fba714c81d
|
|
| MD5 |
4c1b74bf9c518dc4d9dc74b9614975d5
|
|
| BLAKE2b-256 |
a4080350a64b88c1ed0c58dfb42d62b70152e171c3cf9e14a5ab8d049c2a670c
|
File details
Details for the file pyehr_openehr-0.0.6-py3-none-any.whl.
File metadata
- Download URL: pyehr_openehr-0.0.6-py3-none-any.whl
- Upload date:
- Size: 252.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
471c75826d2a653cd12dc0ca967d4e214141a17dab7ad5b4173252650061dd6b
|
|
| MD5 |
521e7203d7175ac9070a4e234d6acba8
|
|
| BLAKE2b-256 |
cc500dde2db4eebea4e4a2089a0885cfa33ac1b102a3457291bcd179032b2b33
|