hl7-parser

Parses the structure of HL7v2 messages, but does not validate the correctness of the messages.
[!WARNING]
Although a best effort has been made to make this parse HL7v2 messages correctly, there are no guarantees that it is actually correct. Use at your own risk.
Features
- Parse HL7v2 messages into a structure that can be queried
- Parse HL7v2 timestamps into chrono or time types
- Decode HL7v2 encoded strings
- Locate a cursor within a message based on a character index
- Optional lenient parsing of segment separators (allow
\r\n
,\n
, and\r
to count as segment separators instead of just\r
) - Non-ASCII/UTF-8 encodings
(Unchecked features are not yet implemented, but planned for future releases).
Usage
Add this to your Cargo.toml
:
[]
= "0.2"
and then you can parse HL7v2 messages:
use ParsedMessage;
let message = include_str!;
let message = parse.expect;
let trigger_event = message.query_value.expect;
assert_eq!;
Optional Cargo Features
By default, no optional features are enabled.
serde
: enable serde support for all data structurestime
: enable time support for parsing timestampschrono
: enable chrono support for parsing timestamps
Examples
Parsing a ParsedMessage
use ParsedMessage;
use NonZeroUsize;
let message = r#"
MSH|^~\&|AccMgr|1|||20050110045504||ADT^A01|599102|P|2.3|||
PID|1||10006579^^^1^MRN^1||DUCK^DONALD^D||19241010|M||1|111 DUCK ST^^FOWL^CA^999990000^^M|1|8885551212|8885551212|1|2||40007716^^^AccMgr^VN^1|123121234|||||||||||NO NK1|1|DUCK^HUEY|SO|3583 DUCK RD^^FOWL^CA^999990000|8885552222||Y||||||||||||||
PV1|1|I|PREOP^101^1^1^^^S|3|||37^DISNEY^WALT^^^^^^AccMgr^^^^CI|||01||||1|||37^DISNEY^WALT^^^^^^AccMgr^^^^CI|2|40007716^^^AccMgr^VN|4|||||||||||||||||||1||G|||20050110045253||||||
"#;
let message = parse.expect;
let message_type = message.get_field_source;
assert_eq!;
Querying a ParsedMessage
use ParsedMessage;
let message = include_str!;
let message = parse.expect;
let trigger_event = message.query_value.expect;
assert_eq!;
Locating the Cursor Within A ParsedMessage
(The cursor being the character index of some point within the buffer)
use ParsedMessage;
use NonZeroUsize;
let message = r#"
MSH|^~\&|AccMgr|1|||20050110045504||ADT^A01|599102|P|2.3|||
PID|1||10006579^^^1^MRN^1||DUCK^DONALD^D||19241010|M||1|111 DUCK ST^^FOWL^CA^999990000^^M|1|8885551212|8885551212|1|2||40007716^^^AccMgr^VN^1|123121234|||||||||||NO NK1|1|DUCK^HUEY|SO|3583 DUCK RD^^FOWL^CA^999990000|8885552222||Y||||||||||||||
PV1|1|I|PREOP^101^1^1^^^S|3|||37^DISNEY^WALT^^^^^^AccMgr^^^^CI|||01||||1|||37^DISNEY^WALT^^^^^^AccMgr^^^^CI|2|40007716^^^AccMgr^VN|4|||||||||||||||||||1||G|||20050110045253||||||
"#;
let message = parse.expect;
let location = message.locate_cursor;
assert_eq!;
assert_eq!;
assert_eq!;
Parsing ParsedMessage Timestamps
Using the time
crate
use parse_timestamp_time;
let ts = "20230312195905-0700";
let ts = parse_timestamp_time.expect;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
Using the chrono
crate
use parse_timestamp_chrono;
use *;
let ts = "20230312195905-0700";
let ts = parse_timestamp_chrono.expect;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
assert_eq!;
Decoding Encoded Strings
use Separators;
let separators = default;
assert_eq!;