我有一个将.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>元素对dataset中的每条记录都重复。
<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语句的组合来获得我想要的东西,但是到目前为止我还不能让它工作。任何帮助都将不胜感激。
发布于 2011-01-11 12:56:16
此转换
<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 元素与覆盖模板匹配。这将在结果中创建唯一的elements.id,并将模板应用于所有与覆盖模板匹配的Table 元素的子元素,该将其转换为具有id属性和id元素值的employee元素。这还会将employee元素内部的模板应用于id的所有其他同级,并且身份模板会按原样复制这些模板。发布于 2011-01-11 12:58:24
这应该能起到作用
<?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>https://stackoverflow.com/questions/4654225
复制相似问题