如何将XML元素组转换为JSON列表? [英] How to convert groups of XML elements to JSON lists?
本文介绍了如何将XML元素组转换为JSON列表?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
是否可以应用仅在唯一属性上匹配的模板?
Is it possible to apply a template that only matchings on the unique attributes?
<node name="region">1</node>
<node name="region">2</node>
<node name="region">3</node>
<node name="place">a</node>
<node name="place">b</node>
<node name="title">test</node>
我想对@name="region"
执行一次模板,对@name="place"
执行一次.可以使用XSLT/XPath 1.0完成吗?
I want to execute a template once for @name="region"
and once for @name="place"
. Can this be done using XSLT/XPath 1.0?
我的最终目标是看起来像这样的JSON输出:
"container":{
"region":["1","2","3"],
"place":["a","b"],
"title":"test"
}
推荐答案
Muenchian分组方法
您可以使用 Muenchian方法解决分组问题.
此输入XML
<container>
<node name="region">1</node>
<node name="region">2</node>
<node name="region">3</node>
<node name="place">a</node>
<node name="place">b</node>
<node name="title">test</node>
</container>
此XSLT提供的
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="text"/>
<xsl:key name="nodes-by-name" match="node" use="@name"/>
<xsl:template match="container">
<xsl:text>"container": {
</xsl:text>
<xsl:for-each select="node[count(. | key('nodes-by-name', @name)[1]) = 1]">
<xsl:value-of select="concat('"', @name, '":')"/>
<xsl:choose>
<xsl:when test="count(key('nodes-by-name', @name)) = 1">
<xsl:value-of select="concat('"', ., '"')"/>
</xsl:when>
<xsl:otherwise>
<xsl:text>[</xsl:text>
<xsl:for-each select="key('nodes-by-name', @name)">
<xsl:value-of select="concat('"', ., '"')"/>
<xsl:if test="position() != last()">,</xsl:if>
</xsl:for-each>
<xsl:text>]</xsl:text>
</xsl:otherwise>
</xsl:choose>
<xsl:if test="position() != last()">,</xsl:if>
<xsl:text>
</xsl:text>
</xsl:for-each>
<xsl:text>}</xsl:text>
</xsl:template>
</xsl:stylesheet>
产生此XML输出,
"container": {
"region":["1","2","3"],
"place":["a","b"],
"title":"test"
}
根据要求.
这篇关于如何将XML元素组转换为JSON列表?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文