-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathprocedure.py
89 lines (73 loc) · 2.75 KB
/
procedure.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import re
from typing import List, Optional, Union
from pydantic import validator
from linuxforhealth.csvtofhir.fhirutils import csv_record_validator as csvrecord
from linuxforhealth.csvtofhir.model.csv.base import CsvBaseModel
DEFAULT_STATUS = "unknown"
class ProcedureCsv(CsvBaseModel):
patientInternalId: Optional[str]
accountNumber: Optional[str]
ssn: Optional[str]
ssnSystem: Optional[str]
mrn: Optional[str]
procedureSourceRecordId: Optional[str]
encounterInternalId: Optional[str]
encounterNumber: Optional[str]
encounterClaimType: Optional[str]
resourceInternalId: Optional[str]
assigningAuthority: Optional[str]
procedureStatus: Optional[str]
procedurePerformedDateTime: Optional[str]
procedureCategory: Optional[str]
procedureCategorySystem: Optional[str]
procedureCategoryText: Optional[str]
procedureCode: Optional[str]
procedureCodeSystem: Optional[str]
procedureCodeDisplay: Optional[str]
procedureCodeText: Optional[str]
procedureCodeList: Optional[List[str]]
procedureModifierList: Optional[str]
procedureModifierSystem: Optional[str]
procedureEncounterSequenceId: Optional[str] # Must be a positive int
practitionerInternalId: Optional[str]
practitionerNPI: Optional[str]
practitionerNameLast: Optional[str]
practitionerNameFirst: Optional[str]
practitionerGender: Optional[str]
practitionerRoleText: Optional[str]
practitionerRoleCode: Optional[str]
practitionerRoleCodeSystem: Optional[str]
practitionerSpecialtyCode: Optional[str]
practitionerSpecialtyCodeSystem: Optional[str]
practitionerSpecialtyText: Optional[str]
@validator("ssn")
def validate_ssn(cls, v):
return csvrecord.validate_ssn(v)
@validator("procedureStatus", always=True)
def validate_procedureStatus(cls, v):
if v:
return v
return DEFAULT_STATUS
def has_encounter_data(self) -> bool:
return any(
[
self.encounterInternalId,
self.encounterNumber,
self.procedureEncounterSequenceId
]
)
def get_modifier_list(self) -> Union[list, None]:
if not self.procedureModifierList:
return None
if isinstance(self.procedureModifierList, list):
return self.procedureModifierList
if not isinstance(self.procedureModifierList, str):
return None
modifier_list = self.procedureModifierList.strip()
if modifier_list.isalnum():
modifiers = [
modifier_list[i: i + 2] for i in range(0, len(modifier_list), 2)
]
else:
modifiers = [x for x in re.split("[\\s,;]", modifier_list) if x]
return modifiers