第三課:信道学习Source Connect Reader & Destinations File Writer

第一步: 切换到主信道(Channels)界面,右键点击新建信道(New Channel)

第二步 : 下面是设置一些信道概要(Summary)信息

其中summary(概要) 界面主要包含 信道名称,数据类型,依赖,信道初始状态,附件(是否存储附件),Tag(标签)

  1. 输入信道的名字 例如: Simple1

  2. 添加信道标签,如Test,标签的作用用于以后对信道进行分类

  3. 设置入站和出站格式: HL7v2.x

            4.点击“Save Changes”保存信道

第三步: 配置源通道(Source Connector)

切换到Source标签,来配置源通道,用于指定信道怎么从通道读取消息,为了试验的目的,我们选择的是Connector Reader,从Mirth Conect Administrator接口发送消息,因此不要任何应用测试我们创建的信道。

源通道的类型有很多,包括: Channel Reader,DICOM Listener,Database Reader,File Reader,Http Listener,JMS Listener,JavaScript Reader,TCP Listener,Web Service Listener.

第四步:配置目标通道(Destinations Connector)

将目标通道设置为文件写入器File Writer。将文件夹指定为F:\MirthConnect\Test\Out,文件名指定为out.hl7

第五步:接下来,选择Source页签,单击左侧菜单上的Edit Transformer,这是我们定义转换规则的地方,如下图所示

我们添加入站消息模板。单击右侧的“消息模板”选项卡,然后使用以下示例:

MSH|^~\&|SIEMENS|HOSPITAL-A|CERNER|HOSPITAL-A|201401291848||ADT^A01|1912340911|P|2.3|||AL|NE|
EVN|A01|201401291848|||REJKB1
PID||ABC123|987654|ALT789|PETTY^TOM^^^^||19781218|M||2106-3|10144 MAPLE AVE^^IRVINE^CA^92614||(949)123-1234|||||0053820452|220675537||AME||||1|||||
PV1||I|S-2302-1^S-2302^A|C|||1111111^PINA|||SUR|||||A0||1111111^PINA|S||S|P||||||||||||||||||IAH|||||201401291848|
PV2||D|42.41^Partial esophagectomy^I9|||||201401290900|201401310900|3|3||||||||||||||||||||||||||

现在,单击Message Tress选项卡以在解析的结构中查看该数据。当您展开各个细分字段时,Mirth将细分示例数据并显示给您。

我们这样做的原因是可以拖放访问正确的字段名称。您可以将带有绿点的字段拖到编码窗口

我们现在开始配置转换器,我们点击左侧Edit Transformer,Transformer Tasks界面。 我们新建一个Step.然后选择,Type = JavaScript

以下测试代码帮我们完成四件事:

  • HL7版本设置为2.4

  • 将发件人ID重新分配给Mirth

  • 将日期和时间更新为MSH段中的当前时间

  • EVN段中用00秒填充日期和时间秒

  • 强制Admit Reason为大写

  • 强制执行目的地的性别列表。基本上,如果我们遇到了意想不到的性别,我们会将其指定为其他的“O”。以下列表是翻译成代码的内容:

// revise to version 2.4
msg['MSH']['MSH.12']['MSH.12.1'] = '2.4';

// sender id
msg['MSH']['MSH.3']['MSH.3.1'] = 'MIRTH';

// update datetime
msg['MSH']['MSH.7']['MSH.7.1'] = DateUtil.getCurrentDate('yyyyMMddhhmmss');

// Add two digits of seconds if they aren't there.
if (msg['EVN']['EVN.2']['EVN.2.1'].toString().length <= 12)
{
msg['EVN']['EVN.2']['EVN.2.1'] = PadString('00000000000000', msg['EVN']['EVN.2']['EVN.2.1'].toString(), 0);
}

// Check whether or not gender meets requirements of the destination system. Set to 'O' if not.
switch(msg['PID']['PID.8']['PID.8.1'].toString().toUpperCase())
{
case 'F':
msg['PID']['PID.8']['PID.8.1'] = 'F';
break;
case 'M':
msg['PID']['PID.8']['PID.8.1'] = 'M';
break;
case 'O':
msg['PID']['PID.8']['PID.8.1'] = 'O';
break;
case 'U':
msg['PID']['PID.8']['PID.8.1'] = 'U';
break;
case 'A':
msg['PID']['PID.8']['PID.8.1'] = 'A';
break;
case 'N':
msg['PID']['PID.8']['PID.8.1'] = 'N';
break;

default: msg['PID']['PID.8']['PID.8.1'] = 'O';
}

// Set admit reason to all upper case
msg['PV2']['PV2.3']['PV2.3.2'] = msg['PV2']['PV2.3']['PV2.3.2'].toString().toUpperCase();

在第13行,您会注意到我们调用了一个名为PadString的函数。函数的作用呢,很简单啦,就是我们在某一个地方定义函数,之后在Mirth Connect中的所有Channel都可以使用。

那么,在什么地方定义函数呢??

第六步:请返回主信道菜单(Channels)并创建代码模板库,添加以下代码模板功能

 

/**

Modify the description here. Modify the function name and parameters as needed. One function per

template is recommended; create a new code template for each new function.



@padchars Example '0000000000' – pad with 0's to 10 digits total

@str your input string

@padLeft 1 for left or 0 for right



@return {String} return description

*/

function PadString(padchars, str, padLeft)

{

if (typeof str === 'undefined')

return padchars;

if (padLeft) {

return (padchars + str).slice(-padchars.length);

} else {

return (str + padchars).substring(0, padchars.length);

}

}

OK!!

第七步:信道Simple1指定依赖的自定义库函数

第八步:现在,让我们回到我们信道主界面并部署它

F:\MirthConnect\Test\In目录中设置一个示例文件,名为SimpleHL723.txt

内容如下:

MSH|^~\&|SIEMENS|HOSPITAL-A|CERNER|HOSPITAL-A|201401291848||ADT^A01|1912340911|P|2.3|||AL|NE|
EVN|A01|201401291848|||REJKB1
PID||ABC123|987654|ALT789|PETTY^TOM^^^^||19781218|M||2106-3|10144 MAPLE AVE^^IRVINE^CA^92614||(949)123-1234|||||0053820452|220675537||AME||||1|||||
PV1||I|S-2302-1^S-2302^A|C|||1111111^PINA|||SUR|||||A0||1111111^PINA|S||S|P||||||||||||||||||IAH|||||201401291848|
PV2||D|42.41^Partial esophagectomy^I9|||||201401290900|201401310900|3|3||||||||||||||||||||||||||

第九步:按以下步骤发送SimpleHL723.txt文件内容到Simple1信道

这时,打开F:\MirthConnect\Test\Out目录中out.hl7文件即可看到已经HL2.3转换为HL72.4,如下:

总结以下,通过这个示例,我们学习了Mirth Connect的以下知识:

1.创建信道Channel的操作步骤

2.创建自定义函数模板Edit Code Templates的操作步骤

3.学习了SourceEdit Transformer的转换JS操作

4.学习了SourceConnect Reader通道;DestinationsFile Writer通道。

posted @ 2021-01-20 15:42  潤沁網路大學  阅读(991)  评论(0)    收藏  举报
潤沁網路大學