我希望将HL7 v2(旧的EDI格式)消息转换为JSON,这样我就可以使它们在Apache Drill下可处理,在Parquet下可压缩。我研究了HAPI,但是我没有找到用于非XML HL7到JSON转换的实用程序。有人对图书馆有建议或参考吗?
oyjwcjzk1#
只需使用HAPI转换为XML即可。下面的代码需要Saxon,因为XML-to-JSON需要XSLT 2.0,但是如果您已经有了一个将XML转换为JSON的方法,那么您只需要前两行代码,它们完全是HAPI。当然,您应该在本地下载XSLT进行生产。:-)
String convertHL7ToJson(Message message) { try { DefaultXMLParser xmlParser = new DefaultXMLParser(new CanonicalModelClassFactory("2.6")); String xml = xmlParser.encode(message); Transformer xmlTransformer = TransformerFactory.newInstance("net.sf.saxon.TransformerFactoryImpl", null).newTransformer( new StreamSource(new StringReader(readFileFromURL("https://github.com/bramstein/xsltjson/raw/master/conf/xml-to-json.xsl"))) ); StringWriter result = new StringWriter(); xmlTransformer.transform( new StreamSource(new StringReader(xml)), new StreamResult(result) ); return result.toString(); } catch (Throwable t) { t.printStackTrace(); } return null; } String readFileFromURL(String url) { InputStream is = null; try { return new Scanner(is = new URL(url).openStream(), "UTF-8").useDelimiter("\\A").next(); } catch (Throwable t) { t.printStackTrace(); } finally { if(is != null) try { is.close(); } catch (Throwable ignored){} } return null; }
这将创建如下所示的输出:
"ORM_O01":{"MSH":{"MSH.1":"|","MSH.2":"^~\\&","MSH.3":{"HD.1":"TEST"},"MSH.4":{"HD.1":"TEST000","HD.2":"BL"},...
ej83mcc02#
如果有一种方法可以将HL7转换为XML,那么您可以使用Drill原生地查询XML 1,然后最终将其转换为parquet。
2条答案
按热度按时间oyjwcjzk1#
只需使用HAPI转换为XML即可。下面的代码需要Saxon,因为XML-to-JSON需要XSLT 2.0,但是如果您已经有了一个将XML转换为JSON的方法,那么您只需要前两行代码,它们完全是HAPI。当然,您应该在本地下载XSLT进行生产。:-)
这将创建如下所示的输出:
ej83mcc02#
如果有一种方法可以将HL7转换为XML,那么您可以使用Drill原生地查询XML 1,然后最终将其转换为parquet。