鉴于此xml
<Documents>
<Section>
<SectionName>Green</SectionName>
<Document>
<FileName>Tier 1 Schedules</FileName>
</Document>
<Document>
<FileName>Tier 3 Schedules</FileName>
</Document>
<Document>
<FileName>Setback Schedule</FileName>
</Document>
<Document>
<FileName>Tier 2 Governance</FileName>
</Document>
</Section>
<Section>
<SectionName>MRO/Refurb</SectionName>
<Document>
<FileName>Tier 2 Governance</FileName>
</Document>
</Section>
</Documents>
输出此html
的xslt是什么?<table>
<tr>
<td>Green</td>
</tr>
<tr>
<td>Tier 1 Schedules</td>
</tr>
<tr>
<td>Tier 3 Schedules</td>
</tr>
<tr>
<td>Setback Schedule</td>
</tr>
<tr>
<td>Tier 2 Governance</td>
</tr>
<tr>
<td>MRO/Refurb</td>
</tr>
<tr>
<td>Tier 2 Governance</td>
</tr>
</table>
我可以在asp.net中执行此操作但不确定如何在xslt中执行循环。
谢谢, 人
答案 0 :(得分:3)
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
>
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes" />
<xsl:template match="/">
<table>
<xsl:apply-templates select="//SectionName | //FileName" />
</table>
</xsl:template>
<xsl:template match="SectionName | FileName">
<tr>
<td><xsl:value-of select="." /></td>
</tr>
</xsl:template>
</xsl:stylesheet>
答案 1 :(得分:2)
实际上,有一个比Tomalak提出的解决方案更简单的解决方案:
<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="/">
<table>
<xsl:apply-templates/>
</table>
</xsl:template>
<xsl:template match="SectionName | FileName">
<tr>
<td>
<xsl:value-of select="." />
</td>
</tr>
</xsl:template>
</xsl:stylesheet>
将此转换应用于最初提供的XML文档时,生成所需结果:
<table>
<tr>
<td>Green</td>
</tr>
<tr>
<td>Tier 1 Schedules</td>
</tr>
<tr>
<td>Tier 3 Schedules</td>
</tr>
<tr>
<td>Setback Schedule</td>
</tr>
<tr>
<td>Tier 2 Governance</td>
</tr>
<tr>
<td>MRO/Refurb</td>
</tr>
<tr>
<td>Tier 2 Governance</td>
</tr>
</table>
请注意:
<xsl:apply-templates>
指令未明确指定必须处理的节点列表。在这里,我们依赖于以下事实:文档中唯一的非空白空间节点是节点的子节点,我们有一个匹配的模板。
对于这个特定的XML文档,我们甚至可以将<xsl:template match="SectionName | FileName">
的匹配模式更改为:<xsl:template match="text()">
,转换仍会产生想要的结果。< / p>
使用<xsl:strip-space>
指令。
答案 2 :(得分:1)
这样的事情可以解决问题:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="html" indent="yes"/>
<xsl:template match="/">
<table>
<xsl:copy>
<xsl:apply-templates />
</xsl:copy>
</table>
</xsl:template>
<xsl:template match="SectionName">
<tr>
<td>
<xsl:value-of select="."/>
</td>
</tr>
</xsl:template>
<xsl:template match="Document">
<tr>
<td>
<xsl:value-of select="FileName"/>
</td>
</tr>
</xsl:template>
</xsl:stylesheet>
马克