将平面XML转换为嵌套XML
我试图弄清楚如何使用xslt将平面xml文件转换为嵌套xml文件。 下面是我试图转换的平面xml的一个示例。我正在使用XSLT2,因此我可以使用分组命令,但我不知道如何使用 我要寻找的结果结构是:将平面XML转换为嵌套XML,xml,xslt,xslt-2.0,Xml,Xslt,Xslt 2.0,我试图弄清楚如何使用xslt将平面xml文件转换为嵌套xml文件。 下面是我试图转换的平面xml的一个示例。我正在使用XSLT2,因此我可以使用分组命令,但我不知道如何使用 我要寻找的结果结构是: <sources> <sourcetype> <sourcetypename>Career Fair</sourcetypename> <sourcelist> <source> <sour
<sources>
<sourcetype>
<sourcetypename>Career Fair</sourcetypename>
<sourcelist>
<source>
<sourcename>Ann Arbor News Fair</sourcename>
<sourceid>CFE-10001</sourceid>
<eventlist>
<event>
<eventname></eventname>
<eventid></eventid>
</event>
</eventlist>
</source>
</sourcelist>
</sourcetype>
</sources>
职业介绍会
安娜堡新闻展
CFE-10001
---平面XML----
广告牌
广告牌
BLD-200284
活跃的
职业介绍会
安娜堡新闻展
CFE-10001
活跃的
职业介绍会
黑人数据处理协会(BDPA)
CFE-10002
活跃的
职业介绍会
职业概念
CFE-10760
活跃的
为每个组嵌套一堆
元素开始看起来很糟糕,但它完成了任务:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:t="http://www.taleo.com/ws/integration/toolkit/2005/07">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="/">
<sources>
<xsl:for-each-group select="/*/t:record"
group-by="t:field[@name='TypeName']">
<sourcetype>
<sourcetypename>
<xsl:value-of select="current-grouping-key()"/>
</sourcetypename>
<sourcelist>
<xsl:for-each-group select="current-group()"
group-by="t:field[@name='SourceID']">
<source>
<sourcename>
<xsl:value-of select="t:field[@name='SourceName']"/>
</sourcename>
<sourceid>
<xsl:value-of select="current-grouping-key()"/>
</sourceid>
<eventlist>
<xsl:for-each-group
select="current-group()" group-by="t:field[@name='EventID']">
<event>
<eventname>
<xsl:value-of
select="t:field[@name='EventName']"/>
</eventname>
<eventid>
<xsl:value-of
select="current-grouping-key()"/>
</eventid>
</event>
</xsl:for-each-group>
</eventlist>
</source>
</xsl:for-each-group>
</sourcelist>
</sourcetype>
</xsl:for-each-group>
</sources>
</xsl:template>
</xsl:stylesheet>
输出:
<sources xmlns:t="http://www.taleo.com/ws/integration/toolkit/2005/07">
<sourcetype>
<sourcetypename>Billboards</sourcetypename>
<sourcelist>
<source>
<sourcename>Billboard</sourcename>
<sourceid>BLD-200284</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
</sourcelist>
</sourcetype>
<sourcetype>
<sourcetypename>Career Fair</sourcetypename>
<sourcelist>
<source>
<sourcename>Ann Arbor News Fair</sourcename>
<sourceid>CFE-10001</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
<source>
<sourcename>Black Data Processing Association (BDPA) </sourcename>
<sourceid>CFE-10002</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
<source>
<sourcename>Career Concepts</sourcename>
<sourceid>CFE-10760</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
</sourcelist>
</sourcetype>
</sources>
广告牌
广告牌
BLD-200284
职业介绍会
安娜堡新闻展
CFE-10001
黑人数据处理协会(BDPA)
CFE-10002
职业概念
CFE-10760
为每个组嵌套一堆
元素开始看起来很糟糕,但它完成了任务:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:t="http://www.taleo.com/ws/integration/toolkit/2005/07">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="/">
<sources>
<xsl:for-each-group select="/*/t:record"
group-by="t:field[@name='TypeName']">
<sourcetype>
<sourcetypename>
<xsl:value-of select="current-grouping-key()"/>
</sourcetypename>
<sourcelist>
<xsl:for-each-group select="current-group()"
group-by="t:field[@name='SourceID']">
<source>
<sourcename>
<xsl:value-of select="t:field[@name='SourceName']"/>
</sourcename>
<sourceid>
<xsl:value-of select="current-grouping-key()"/>
</sourceid>
<eventlist>
<xsl:for-each-group
select="current-group()" group-by="t:field[@name='EventID']">
<event>
<eventname>
<xsl:value-of
select="t:field[@name='EventName']"/>
</eventname>
<eventid>
<xsl:value-of
select="current-grouping-key()"/>
</eventid>
</event>
</xsl:for-each-group>
</eventlist>
</source>
</xsl:for-each-group>
</sourcelist>
</sourcetype>
</xsl:for-each-group>
</sources>
</xsl:template>
</xsl:stylesheet>
输出:
<sources xmlns:t="http://www.taleo.com/ws/integration/toolkit/2005/07">
<sourcetype>
<sourcetypename>Billboards</sourcetypename>
<sourcelist>
<source>
<sourcename>Billboard</sourcename>
<sourceid>BLD-200284</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
</sourcelist>
</sourcetype>
<sourcetype>
<sourcetypename>Career Fair</sourcetypename>
<sourcelist>
<source>
<sourcename>Ann Arbor News Fair</sourcename>
<sourceid>CFE-10001</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
<source>
<sourcename>Black Data Processing Association (BDPA) </sourcename>
<sourceid>CFE-10002</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
<source>
<sourcename>Career Concepts</sourcename>
<sourceid>CFE-10760</sourceid>
<eventlist>
<event>
<eventname/>
<eventid/>
</event>
</eventlist>
</source>
</sourcelist>
</sourcetype>
</sources>
广告牌
广告牌
BLD-200284
职业介绍会
安娜堡新闻展
CFE-10001
黑人数据处理协会(BDPA)
CFE-10002
职业概念
CFE-10760
我在猜测最终输出,因为我不确定分组应该是什么,但下面是另一个2.0分组解决方案:
XSLT2.0
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/*:ExportXML">
<sources>
<xsl:for-each-group select="*:record" group-by="*:field[@name='TypeName']">
<xsl:variable name="vType" select="*:field[@name='TypeName']"/>
<sourcetype>
<sourcetypename>
<xsl:apply-templates select="*:field[@name='TypeName']" mode="title"/>
</sourcetypename>
<sourcelist>
<xsl:apply-templates select="/*/*:record[*:field[@name='TypeName'][.=$vType]]"/>
</sourcelist>
</sourcetype>
</xsl:for-each-group>
</sources>
</xsl:template>
<xsl:template match="*:field">
<xsl:element name="{lower-case(@name)}">
<xsl:apply-templates/>
</xsl:element>
</xsl:template>
<xsl:template match="*:record">
<source>
<xsl:apply-templates select="*:field[starts-with(@name,'Source')]"/>
<eventlist>
<event>
<xsl:apply-templates select="*:field[starts-with(@name,'Event')]"/>
</event>
</eventlist>
</source>
</xsl:template>
<xsl:template match="*:field[@name='TypeName']"/>
<xsl:template match="*:field[@name='TypeName']" mode="title">
<xsl:apply-templates/>
</xsl:template>
</xsl:stylesheet>
XML输出(使用提供的XML输入和Saxon HE 9.3)
广告牌
广告牌
BLD-200284
职业介绍会
安娜堡新闻展
CFE-10001
黑人数据处理协会(BDPA)
CFE-10002
汽车