[英]xslt transform of dynamic xml
I have an xml similar to the one as follows 我有一个类似于下面的xml
<DataSet1>
<Table1>
<Column1>Value111</Column1>
<Column2>Value112</Column2>
</Table1>
<Table1>
<Column1>Value121</Column1>
<Column2>Value122</Column2>
</Table1>
<Table1>
<Column1>Value131</Column1>
<Column2>Value132</Column2>
</Table1>
<Table2>
<Column1>Value211</Column1>
<Column2>Value212</Column2>
</Table2>
<Table2>
<Column1>Value221</Column1>
<Column2>Value222</Column2>
</Table2>
<Table2>
<Column1>Value231</Column1>
<Column2>Value232</Column2>
</Table2>
</DataSet1>
Where Table1 and Table2 are added dynamically in the dataset. 表1和表2是在数据集中动态添加的。 So there can be n number of tables in dataset as Tablen.
因此,数据集中可以有多个表作为Tablen。
I want to write xsl which produces the html as follows 我想编写生成html的xsl,如下所示
Table1
<table>
<tr>
<td>Value111</td>
<td>Value112</td>
</tr>
<tr>
<td>Value121</td>
<td>Value122</td>
</tr>
<tr>
<td>Value131</td>
<td>Value132</td>
</tr>
</table>
Table2
<table>
<tr>
<td>Value211</td>
<td>Value212</td>
</tr>
<tr>
<td>Value221</td>
<td>Value222</td>
</tr>
<tr>
<td>Value231</td>
<td>Value232</td>
</tr>
</table>
Is there any way to select xsl template as select="DataSet1/Table*" which can match with any table and iterate the structure? 有没有办法选择xsl模板作为select =“DataSet1 / Table *”,它可以与任何表匹配并迭代结构?
Please help!!!. 请帮忙!!!。
This transformation : 这种转变 :
<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:key name="kTableByName" match="*[starts-with(name(),'Table')]"
use="name()"/>
<xsl:template match=
"*[generate-id()
=
generate-id(key('kTableByName', name())[1])
]">
<xsl:value-of select="concat('
', name(), '
')"/>
<table>
<xsl:apply-templates select="key('kTableByName', name())" mode="inGroup"/>
</table>
</xsl:template>
<xsl:template match="*[starts-with(name(),'Table')]" mode="inGroup">
<tr>
<xsl:apply-templates select="*" mode="inGroup"/>
</tr>
</xsl:template>
<xsl:template match="*[starts-with(name(),'Table')]/*" mode="inGroup">
<td>
<xsl:value-of select="."/>
</td>
</xsl:template>
<xsl:template match="text()"/>
</xsl:stylesheet>
when applied on the provided XML document : 当应用于提供的XML文档时 :
<DataSet1>
<Table1>
<Column1>Value111</Column1>
<Column2>Value112</Column2>
</Table1>
<Table1>
<Column1>Value121</Column1>
<Column2>Value122</Column2>
</Table1>
<Table1>
<Column1>Value131</Column1>
<Column2>Value132</Column2>
</Table1>
<Table2>
<Column1>Value211</Column1>
<Column2>Value212</Column2>
</Table2>
<Table2>
<Column1>Value221</Column1>
<Column2>Value222</Column2>
</Table2>
<Table2>
<Column1>Value231</Column1>
<Column2>Value232</Column2>
</Table2>
</DataSet1>
produces the wanted, correct result : 产生想要的,正确的结果 :
Table1
<table>
<tr>
<td>Value111</td>
<td>Value112</td>
</tr>
<tr>
<td>Value121</td>
<td>Value122</td>
</tr>
<tr>
<td>Value131</td>
<td>Value132</td>
</tr>
</table>
Table2
<table>
<tr>
<td>Value211</td>
<td>Value212</td>
</tr>
<tr>
<td>Value221</td>
<td>Value222</td>
</tr>
<tr>
<td>Value231</td>
<td>Value232</td>
</tr>
</table>
Explanation : 说明 :
Proper use of the Muenchian Grouping method . 正确使用Muenchian分组方法 。
Have you tried the w3Schools tutorial on xPath ? 你有没有在xPath上试过w3Schools教程 ? There is a * selector which will allow you to select all children of a certain node like so:
DataSet1/*
有一个*选择器,允许您选择某个节点的所有子节点,如下所示:
DataSet1/*
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.