如何使用 XSLT 将 JSON 转换为 XML?
Posted
技术标签:
【中文标题】如何使用 XSLT 将 JSON 转换为 XML?【英文标题】:How to convert JSON to XML using XSLT? 【发布时间】:2021-07-22 13:27:33 【问题描述】:我想使用 XSLT 将 JSON 转换为 XML。但无法达到预期的输出。 下面是 JSON 请求:
"Store": [
"Book": "Cartoons",
"ID": "ABC"
]
我尝试过的 XSLT:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:math="http://www.w3.org/2005/xpath-functions/math"
xmlns:xd="http://www.oxygenxml.com/ns/doc/xsl"
xmlns:emp="http://www.semanticalllc.com/ns/employees#"
xmlns:h="http://www.w3.org/1999/xhtml"
xmlns:fn="http://www.w3.org/2005/xpath-functions"
xmlns:j="http://www.w3.org/2005/xpath-functions"
exclude-result-prefixes="xs math xd h emp"
version="3.0"
expand-text="yes">
<xsl:template match="/">
<xsl:copy>
<xsl:apply-templates select="json-to-xml(.)/*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="*[@key]" xpath-default-namespace="http://www.w3.org/2005/xpath-functions">
<xsl:element name="@key">
<xsl:apply-templates/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
但我的响应是空的。
【问题讨论】:
我想您的 json 需要在 xml 文件中,或者您将 json 作为根参数传递:请参阅:***.com/q/58113843/3710053 我已经浏览了链接并尝试了。但仍然不适合我。是否可以使用 XSLT 2.0 或 1.0 版本进行转换? 一切皆有可能......“有志者事竟成。”但现在我建议考虑使用 3.0。因此,请将您的 xslt/xml 更新为您的最新尝试。 我已经更新了我尝试使用您提供的链接的 XSLT。同样的问题。不工作。 【参考方案1】:您需要将 JSON 作为参数传递或从文件中读取,XSLT 的输入要么是 XML,要么您可以从命名模板开始:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="#all"
version="3.0">
<xsl:param name="json" as="xs:string" expand-text="no">
"Store": [
"Book": "Cartoons",
"ID": "ABC"
]
</xsl:param>
<xsl:output indent="yes"/>
<xsl:template match="/" name="xsl:initial-template">
<xsl:sequence select="json-to-xml($json)"/>
</xsl:template>
</xsl:stylesheet>
https://xsltfiddle.liberty-development.net/93wniTJ
你的样本函数的结果是
<map xmlns="http://www.w3.org/2005/xpath-functions">
<array key="Store">
<map>
<string key="Book">Cartoons</string>
<string key="ID">ABC</string>
</map>
</array>
</map>
当然,您可以通过更多模板运行它以将其转换为不同的格式。
【讨论】:
但是传入的 JSON 请求值会发生变化。 您可以在每次运行转换之前更改任何全局参数。 示例是 XSLT 3,我不知道是否或如何将它集成到 IBM 数据能力中,如果这是您正在使用的环境。【参考方案2】:模式 match="/" 匹配文档节点(XML 树的根)。如果输入是 JSON,它将与您的输入不匹配。
XSLT 3.0 实际上并不擅长使用模板规则处理 JSON:它可以做到,但不是很方便。使用函数通常更方便。您可以将 JSON 输入作为 xsl:param 的值提供,并在 xsl:initial-template
的代码中对其进行处理;或者,如果您感觉更有野心,您实际上可以通过调用将 JSON 输入作为参数的公共 xsl:function
来启动 XSLT 处理。
样式表中传统的match="/"
条目仅适用于使用 XSLT 处理 XML 输入文档的传统方式。
【讨论】:
嗨迈克尔,我发现在不使用 Convert-query-params 的情况下将 json 转换为 Jsonx 有困难。你能帮我如何使用 gatewayscript 将 Json 转换为 Jsonx 或 XML。在使用 Gatewayscript 时,我浏览了几个 IBM 论坛并遇到了错误。 这需要一个单独的问题——而且可能需要另一个人来回答,因为我对 Json 或 Gatewayscript 一无所知。以上是关于如何使用 XSLT 将 JSON 转换为 XML?的主要内容,如果未能解决你的问题,请参考以下文章
如何停止 xslt3.0 的 xml-to-json() 函数将数字转换为指数表示法
使用自定义 XSLT 将 XML 转换为 JSON 会丢失花括号