我有一个场景,我将.net数据集导出到xml文件,但我想将xml输出的结构转换为更多层次结构。下面是dataset.xmlwrite()方法导出的数据集格式。
<NewDataSet>
<Table>
<id>100</id>
<empname>Joe Smith</empname>
<phone>111-111-1111</phone>
<mobile>222-222-2222</mobile>
</Table>
<Table>
<id>101</id>
<empname>Ann Jensen</empname>
<phone>111-111-0000</phone>
<mobile>222-222-0000</mobile>
</Table>
<NewDataSet>
我想将其转换为以下结构。我是xsl转换的新手,我不确定如何保持<Table>
元素不会重复数据集中的每条记录。
<NewDataSet>
<Table>
<employee id="100">
<empname>Joe Smith</empname>
<phone>111-111-1111</phone>
<mobile>222-222-2222</mobile>
</employee>
<employee id="101">
<empname>Ann Jensen</empname>
<phone>111-111-0000</phone>
<mobile>222-222-0000</mobile>
</employee>
</Table>
<NewDataSet>
我尝试使用xsl:for-each和xsl:if语句的组合来获得我想要的东西,但到目前为止我还没有能够让它工作。非常感谢任何帮助。
答案 0 :(得分:2)
此转化:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="Table[1]">
<Table>
<xsl:apply-templates select="../Table/id"/>
</Table>
</xsl:template>
<xsl:template match="Table[position()>1]"/>
<xsl:template match="Table/id">
<employee id="{.}">
<xsl:apply-templates select=
"following-sibling::node()"/>
</employee>
</xsl:template>
</xsl:stylesheet>
应用于提供的XML文档(更正格式正确):
<NewDataSet>
<Table>
<id>100</id>
<empname>Joe Smith</empname>
<phone>111-111-1111</phone>
<mobile>222-222-2222</mobile>
</Table>
<Table>
<id>101</id>
<empname>Ann Jensen</empname>
<phone>111-111-0000</phone>
<mobile>222-222-0000</mobile>
</Table>
</NewDataSet>
生成想要的正确结果:
<NewDataSet>
<Table>
<employee id="100">
<empname>Joe Smith</empname>
<phone>111-111-1111</phone>
<mobile>222-222-2222</mobile>
</employee>
<employee id="101">
<empname>Ann Jensen</empname>
<phone>111-111-0000</phone>
<mobile>222-222-0000</mobile>
</employee>
</Table>
</NewDataSet>
<强>解释强>:
身份规则“按原样”复制每个节点。
第一个Table
元素由覆盖模板匹配。这会在结果中创建唯一的Table
,并将模板应用于所有Table
元素的子元素。
id
元素与覆盖模板匹配,将其转换为employee
元素,其id
属性的值为id
元素。这也将employee
元素内的模板应用于id
的所有其他兄弟,并通过身份模板按原样复制。
答案 1 :(得分:2)
这应该可以解决问题
<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<Table>
<xsl:for-each select="/NewDataSet/Table">
<employee>
<xsl:attribute name="id"><xsl:value-of select="id/."/></xsl:attribute>
<xsl:for-each select="*">
<xsl:choose>
<xsl:when test="name() = 'id' "/>
<xsl:otherwise>
<xsl:copy-of select="."/>
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</employee>
</xsl:for-each>
</Table>
</xsl:template>
</xsl:stylesheet>