Observation
Introduction #
The Observation model represents measurements or assertions made about a patient, such as vital signs, lab results, or other clinical findings.
Basic usage #
To get an observation by identifier, use the get method on the Observation model manager:
from canvas_sdk.v1.data.observation import Observation
observation = Observation.objects.get(id="b80b1cdc-2e6a-4aca-90cc-ebc02e683f35")
If you have a patient object, the observations for a patient can be accessed with the observations attribute on a Patient object:
from canvas_sdk.v1.data.patient import Patient
patient = Patient.objects.get(id="1eed3ea2a8d546a1b681a2a45de1d790")
observations = patient.observations.all()
If you have a patient ID, you can get the observations for the patient with the for_patient method on the Observation model manager:
from canvas_sdk.v1.data.observation import Observation
patient_id = "1eed3ea2a8d546a1b681a2a45de1d790"
observations = Observation.objects.for_patient(patient_id)
Codings #
The codings for an observation can be accessed with the codings attribute on an Observation object:
from canvas_sdk.v1.data.observation import Observation
from logger import log
observation = Observation.objects.get(id="b80b1cdc-2e6a-4aca-90cc-ebc02e683f35")
for coding in observation.codings.all():
log.info(f"system: {coding.system}")
log.info(f"code: {coding.code}")
log.info(f"display: {coding.display}")
Components #
The components for an observation can be accessed with the components attribute on an Observation object:
from canvas_sdk.v1.data.observation import Observation
from logger import log
observation = Observation.objects.get(id="b80b1cdc-2e6a-4aca-90cc-ebc02e683f35")
for component in observation.components.all():
log.info(f"name: {component.name}")
log.info(f"value: {component.value_quantity}")
log.info(f"unit: {component.value_quantity_unit}")
Component codings #
Component codings can be accessed similarly to codings on the observation, by using the codings attribute on an ObservationComponent object.
Filtering #
Observations can be filtered by any attribute that exists on the model.
By attribute #
Specify an attribute with filter to filter by that attribute:
from canvas_sdk.v1.data.observation import Observation
observations = Observation.objects.filter(effective_datetime__gte="2024-11-20")
By ValueSet #
Filtering by ValueSet works a little differently. The find method on the model manager is used to perform ValueSet filtering:
from canvas_sdk.v1.data.observation import Observation
from canvas_sdk.value_set.v2022.physical_exam import Weight
observations = Observation.objects.find(Weight)
Attributes #
Observation #
| Field Name | Type |
|---|---|
| id | UUID |
| dbid | Integer |
| created | DateTime |
| modified | DateTime |
| originator | CanvasUser |
| committer | CanvasUser |
| entered_in_error | CanvasUser |
| deleted | Boolean |
| patient | Patient |
| is_member_of | Observation |
| category | String |
| units | String |
| value | String |
| note_id | Integer |
| name | String |
| effective_datetime | DateTime |
| codings | ObservationCoding[] |
| members | Observation[] |
| components | ObservationComponent[] |
| value_codings | ObservationValueCoding[] |
ObservationCoding #
| Field Name | Type |
|---|---|
| dbid | Integer |
| system | String |
| version | String |
| code | String |
| display | String |
| user_selected | Boolean |
| observation | Observation |
ObservationComponent #
| Field Name | Type |
|---|---|
| dbid | Integer |
| created | DateTime |
| modified | DateTime |
| observation | Observation |
| value_quantity | String |
| value_quantity_unit | String |
| name | String |
| codings | ObservationComponentCoding[] |
ObservationComponentCoding #
| Field Name | Type |
|---|---|
| dbid | Integer |
| system | String |
| version | String |
| code | String |
| display | String |
| user_selected | Boolean |
| observation_component | ObservationComponent |
ObservationValueCoding #
| Field Name | Type |
|---|---|
| dbid | Integer |
| system | String |
| version | String |
| code | String |
| display | String |
| user_selected | Boolean |
| observation | Observation |