请帮助,我是一个XSLT新手,我正在尝试将一种XML格式转换为另一种格式。
我需要提取唯一的属性值并将值转换为新格式。下面的示例XML显示了原始和新/目标格式。
我花了很多时间试图这样做而没有任何享受。任何人都可以帮忙或给我一些指示?
原始格式:
<base>
<level>
<level2 Name ="AA" value="1"/>
</level>
<level>
<level2 Name ="BB" value="2"/>
</level>
<level>
<level2 Name ="BB" value="3"/>
</level>
<level>
<level2 Name ="CC" value="4"/>
</level>
<level>
<level2 Name ="AA" value="5"/>
</level>
</base>
新格式:
<base>
<levelNames>
<level level2Name ="AA"/>
<level level2Name ="BB"/>
<level level2Name ="CC"/>
</levelNames>
</base>
非常感谢。
答案 0 :(得分:10)
XSLT Soln:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:key name="LevelDistint" match="level2" use="@Name"/>
<xsl:template match="base">
<base>
<levelNames>
<xsl:for-each select="level/level2[generate-id() = generate-id(key('LevelDistint', @Name)[1])]">
<level>
<xsl:attribute name="level2Name"><xsl:value-of select="normalize-space(@Name)"/></xsl:attribute>
</level>
</xsl:for-each>
</levelNames>
</base>
</xsl:template>
</xsl:stylesheet>
XSLT O / P:
<?xml version="1.0" encoding="UTF-8"?>
<base>
<levelNames>
<level level2Name="AA"/>
<level level2Name="BB"/>
<level level2Name="CC"/>
</levelNames>
</base>
答案 1 :(得分:2)
Muenchian grouping technique似乎是缺失的部分。
它的问题相当微不足道,所以我会让你做自己的工作来掌握Muench。
答案 2 :(得分:0)
请创建第一个xsl:key然后你可以轻松使用下面的代码。
xsl:key name =“levelName”match =“level2”use =“@ Name”
<xsl:template match="/">
<xsl:apply-templates/>
</xsl:template>
<xsl:template match="base">
<xsl:element name="{local-name(.)}">
<xsl:element name="levelNames">
<xsl:apply-templates/>
</xsl:element>
</xsl:element>
</xsl:template>
<xsl:template match="level">
<xsl:for-each select="level2[count(.|key('levelName', @Name)[1]) = 1]">
<xsl:sort order="ascending" data-type="text" select="@Name"/>
<xsl:element name="{local-name(..)}">
<xsl:attribute name="level2Name">
<xsl:value-of select="@Name"/>
</xsl:attribute>
</xsl:element>
</xsl:for-each>
</xsl:template>