原文链接 http://blog.csdn.net/ycyangcai/article/details/6643784

Hl7引擎的目标主要是解决将数据按HL7协议的要求标准化,和标准业务的集成和不同系统间标准业务数据的同步。在多年的医院信息化过程中,HL7标准组织和解析最复杂了,下面是我用了多年HL7引擎解析,主要有两个版本1.C#,2.JAVA版的。

本次公开JAVA的

 //引擎类:

 package com.xxxx.hl7;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
//HL7 转换为XML
public class HL7ToXmlConverter {
  //
  public static String ConvertToXml(String sHL7){
    Document document = ConvertToXmlObject(sHL7);
    String hl7str = document.asXML();
    return hl7str;
  }
  //
  public static String ConvertToXml(Document document){
    String hl7str = document.asXML();
    return hl7str;
  }   public static Document ConvertToXmlObject(String sHL7){
    Document document = CreateXmlDoc();
    //把HL7分成段
    String[] sHL7Lines = sHL7.split("\n");
    //去掉XML的关键字
    for (int i = 0; i < sHL7Lines.length; i++){
      sHL7Lines[i] = sHL7Lines[i].replace("^~\\&", "").replace("MSH", "MSH|");
    }
    for (int i = 0; i < sHL7Lines.length; i++){
      // 判断是否空行
      if (sHL7Lines[i] != null){
        String sHL7Line = sHL7Lines[i];
        //通过/r 或/n 回车符分隔
        String[] sFields = GetMessgeFields(sHL7Line);
        // 为段(一行)创建第一级节点
        Element el = document.getRootElement().addElement(sFields[0]);
        // 循环每一行
        Boolean isMsh=true;
        for (int a = 1; a < sFields.length; a++){
        //是否包括HL7的连接符^~\\&
          if (sFields[a].indexOf('^')>0 || sFields[a].indexOf('~')>0 || sFields[a].indexOf('\\')>0 || sFields[a].indexOf('&')>0 ){
          //0:如果这一行有任一分隔符
          //开始操作~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
          //通过~分隔
            String[] sComponents = GetRepetitions(sFields[a]);
            if (sComponents.length > 1){
              //1:如果可以分隔 0001^郭靖^体检号^EQ^AND~0002^东一区^病区号^EQ^AND
              for (int b = 0; b < sComponents.length; b++){
                // Element fieldEl1 = el.addElement(sFields[0] + "." + a);
                CreateComponents(el,sComponents[b],sFields[0],a,b);
              }
            }
            else{
              //1:如果真的只有一个值的 0001^郭靖^体检号^EQ^AND
              // 为字段创建第二级节点
              // Element fieldEl = el.addElement(sFields[0] + "." + a);
              CreateComponents(el,sFields[a],sFields[0],a,0);
              //fieldEl.setText(sFields[a]+"11111111111111");
            }
            //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
          }
          else{
            //0:如果这一行没有任何分隔符
            // 为字段创建第二级节点
            Element fieldEl = el.addElement(sFields[0] + "." + a);
            fieldEl.setText(sFields[a]);
          }
        }
      }//end if
    }//end for
     //修改MSH.1 和 MSH.2的值
    document.selectSingleNode("HL7Message/MSH/MSH.1").setText("|");
    document.selectSingleNode("HL7Message/MSH/MSH.2").setText("~^\\&");
    // document.selectNodes("MSH/MSH.1");
    return document;
  }
  @SuppressWarnings("unused")
  private static Element CreateComponents(final Element el,final String hl7Components,String sField,int a,int b){
    Element componentEl = el.addElement(sField + "." + a);
    // Element componentEl =el;//.addElement(sField + "." + a + "." + b);
    //&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    //通过&分隔
    String[] subComponents = GetSubComponents(hl7Components);
    if (subComponents.length > 1){
      //2.如果有字组,一般是没有的。。。 子分组 用&很少用
    }
    else{
      //2.如果没有了,就用^分组
      String[] sRepetitions = GetComponents(hl7Components);
      if (sRepetitions.length > 1){
        Element repetitionEl = null;
        for (int c = 0; c < sRepetitions.length; c++){
          repetitionEl = componentEl.addElement(sField + "." + a + "." + (c+1));
          repetitionEl.setText(sRepetitions[c]);
        }
      }
      else{
        componentEl.setText(hl7Components);
      }
    }
    //&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    return el;
   } /// <summary>
/// 通过|分隔 字段
/// </summary>
/// <param name="s"></param>
/// <returns></returns>   private static String[] GetMessgeFields(String s){
    return s.split("\\|");
  }
/// <summary>
/// 通过^分隔 组字段
/// </summary>
/// <param name="s"></param>
/// <returns></returns>   private static String[] GetComponents(String s){
    return s.split("\\^");
  }
/// <summary>
/// 通过&分隔 子分组组字段
/// </summary>
/// <param name="s"></param>
/// <returns></returns>   private static String[] GetSubComponents(String s){
    return s.split("&");
  }
/// <summary>
/// 通过~分隔 重复
/// </summary>
/// <param name="s"></param>
/// <returns></returns>
  private static String[] GetRepetitions(String s){
    return s.split("~");
  }
/// <summary>
/// 创建XML对象
/// </summary>
/// <returns></returns>
  private static Document CreateXmlDoc(){
    Document output = DocumentHelper.createDocument();
    //生成一个接点
    Element rootNode = output.addElement("HL7Message");
    return output;
  }
  public static String GetText(Document document, String path){
    Node node = document.selectSingleNode("HL7Message/"+path);
    if (node != null){
      return node.getText();
    }
    else{
      return null;
    }
  }
  public static String GetText(Document document, String path,int index){
    List nodes = document.selectNodes("HL7Message/"+path);
    if(nodes!=null){
      return ((Node)nodes.get(index)).getText();
    }
    else{
      return null;
    }
  }    //
  public static List GetTexts(Document document, String path){
    List nodes = document.selectNodes("HL7Message/"+path);
    return nodes;
  } //
  public static void writeDocument(Document document, String filepath){
    try{
    //读取文件
    // FileWriter fileWriter = new FileWriter(filepath);
    Writer writer = new OutputStreamWriter(new FileOutputStream(filepath),"utf-8");
    //设置文件编码
    OutputFormat xmlFormat = new OutputFormat();
    xmlFormat.setEncoding("utf-8");
    //创建写文件方法
    XMLWriter xmlWriter = new XMLWriter(writer,xmlFormat);
    //写入文件
    xmlWriter.write(document);
    //关闭
    xmlWriter.close();
    }catch(IOException e){
      System.out.println("文件没有找到");
      e.printStackTrace();
    }
  }
}

单元测试调用类:

  String myHL7string="MSH|^~\\&|455755610_0100||0200||20110624160404|000|QRY^A19^QRY_A19|0123456001|P|2.6\nQRD|||||||||0001^郭靖^体检号^EQ^AND~0002^东一区^病区号^EQ^AND\nQRF||20110627|20110803";
Document document = HL7ToXmlConverter.ConvertToXmlObject(myHL7string);
//获取事件
String eventName = HL7ToXmlConverter.GetText(document, "MSH/MSH.9/MSH.9.3");
System.out.println("eventName:"+eventName);
// List nodeValue = document.selectNodes("MSH.1");
String nodeValue = document.selectSingleNode("HL7Message/MSH/MSH.1").getText();
String nodeValue2 = document.selectSingleNode("HL7Message/MSH/MSH.3").getText();
// DocumentElement.SelectNodes(path);
System.out.println(nodeValue+":"+nodeValue2);
String value = HL7ToXmlConverter.GetText(document, "QRD/QRD.9/QRD.9.1",0);
String value1 = HL7ToXmlConverter.GetText(document, "QRD/QRD.9/QRD.9.1",1);
String value2 = HL7ToXmlConverter.GetText(document, "QRD/QRD.9/QRD.9.1");
System.out.println(value+":"+value1+":"+value2);
List<Node> list = HL7ToXmlConverter.GetTexts(document, "QRD/QRD.9/QRD.9.1");
for(Node node : list)
{
System.out.println(":"+node.getText());
}
System.out.println(HL7ToXmlConverter.ConvertToXml(myHL7string));

hl7 java 解析的更多相关文章

  1. java解析xml的三种方法

    java解析XML的三种方法 1.SAX事件解析 package com.wzh.sax; import org.xml.sax.Attributes; import org.xml.sax.SAXE ...

  2. atitit.java解析sql语言解析器解释器的实现

    atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...

  3. java 解析XML文档

    Java 解析XML文档 一.解析XML文档方式: 1.DOM方式:将整个XML文档读取到内存中,按照XML文件的树状结构图进行解析. 2.SAX方式:基于事件的解析,只需要加载XML中的部分数据,优 ...

  4. Java 解析 XML

    Java 解析 XML 标签: Java基础 XML解析技术有两种 DOM SAX DOM方式 根据XML的层级结构在内存中分配一个树形结构,把XML的标签,属性和文本等元素都封装成树的节点对象 优点 ...

  5. JAVA解析XML的四种方式

    java解析xml文件四种方式 1.介绍 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这 ...

  6. JSON 之JAVA 解析

    一.   JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧. Json建构于两种结构:     1.“名称/值”对的集合(A collection ...

  7. Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)

    [目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...

  8. Java 解析epub格式电子书,helloWorld程序,附带源程序和相关jar包

    秀才坤坤出品 一.epub格式电子书 相关材料和源码均在链接中可以下载:http://pan.baidu.com/s/1bnm8YXT 包括 1.JAVA项目工程test_epub,里面包括了jar包 ...

  9. Java解析XML文档(简单实例)——dom解析xml

      一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...

随机推荐

  1. javascript 压缩空格代码演示

          压缩空格代码演示 主要是讲解 压缩一个字符串两段空格          例如:javascript函数里的空格不论是这样     var s = "Hello World     ...

  2. Linux下如何查看哪些进程占用的CPU内存资源最多

    linux下获取占用CPU资源最多的10个进程,可以使用如下命令组合: ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head linux下获取占用 ...

  3. jquery append 动态添加的元素事件on 不起作用的解决方案

    用jquery添加新元素很容易,面对jquery append 动态添加的元素事件on 不起作用我们该如何解决呢?on方法中要先找到原选择器(如例.info),再找到动态添加的选择器(如列.delet ...

  4. jacob 操作word转pdf

    项目需要对上传的word及pdf进行在线预览,因基于jquery的pdf插件,很方面实现在线预览,而word实现在线预览费劲不少,于是想到在进行上传处理时,直接将word转成pdf,在预览时直接预览p ...

  5. VB6.0 String 用法总结

    问题一 VB 去掉字符串的头尾的空格 使用trim() 如: trim(" hello world ")= "hello world" 问题二 判断一个字符串是 ...

  6. Python urllib和urllib2模块学习(一)

    (参考资料:现代魔法学院 http://www.nowamagic.net/academy/detail/1302803) Python标准库中有许多实用的工具类,但是在具体使用时,标准库文档上对使用 ...

  7. 有趣的keil MDK细节

    1.MDK中的char类型的取值范围是? 在MDK中,默认情况下,char 类型的数据项是无符号的,所以它的取值范围是0-255.它们可以显式地声明为signed char 或 unsigned.因此 ...

  8. 表格无边框,有内框,在table嵌套时,防止出现重复边线

    <html> <head> <title>test 表格无边框,有内框! ^^ CSDN 学习积累</title> <style type=&qu ...

  9. <Win32_20>纯c语言版的打飞机游戏出炉了^_^

    经过昨天的苦战,终于完成了纯C版的打飞机游戏——使用微信打飞机游戏的素材,不过玩法有些不同,下面会有详述 一.概述游戏的玩法.实现效果 1. 游戏第一步,简单判断一下,给你一个准备的时间: 2.选择& ...

  10. Linux学习之十一、环境变量的功能

    环境变量的功能 可以利用两个命令来查阅,分别是 env 与 export 呢! 范例一:列出目前的 shell 环境下的所有环境变量与其内容. [root@www ~]# env SHELL 告知我们 ...