我有许多 xml 文件,我试图从中创建一个 WordML 表。每个节点列表中有多个节点,我需要为每个节点创建一列,最多 15 列。但是,如果少于 15 个,则需要对列进行对齐。
名为 NodeList 的模板:
<xsl:template match="NodeList">
<xsl:for-each select="NodeRef">
<xsl:sort data-type="number" select="@Position" order="ascending"/>
<xsl:sort data-type="text" select="@Name" order="ascending"/>
<xsl:variable name="documentName" select="concat(@Id, '_Nodes.xml')"/>
<xsl:apply-templates mode="SimpleNode" select="document($documentName)/Node"/>
</xsl:for-each>
</xsl:template>
名为 SimpleNode 的模板:
<xsl:template mode="SimpleNode" match="Node">
<!-- Output the Node Table - as template within for-each,
will output table many times -->
<xsl:call-template name="SimpleNodeTable"/>
</xsl:template>
SimpleNodeTable 模板(我卡住的地方):
<xsl:template name="SimpleNodeTable">
<w:tbl>
<w:tblPr>
<w:tblStyle w:val="ReportTable1"/>
<w:tblW w:type="dxa">
<xsl:attribute name="w:w">
<xsl:value-of select="$landscapeBodyWidth"/>
</xsl:attribute>
</w:tblW>
<w:tblLayout w:type="Fixed"/>
</w:tblPr>
<w:tblGrid>
<w:gridCol>
<xsl:attribute name="w:w">
<xsl:value-of select="$nodeNameWidth"/>
</xsl:attribute>
</w:gridCol>
<w:gridCol>
<xsl:attribute name="w:w">
<xsl:value-of select="$landscapeBodyWidth - $nodeNameWidth"/>
</xsl:attribute>
</w:gridCol>
</w:tblGrid>
<w:tr>
<!-- first row -->
<w:tc>
<!-- First cell is blank so vertically merge -->
<w:vmerge w:val="restart"/>
<w:p/>
</w:tc>
<!-- HOW TO DO A FOR EACH LOOP TO ADD 1 COLUMN PER NODEREF?? -->
<xsl:for-each select="Node">
<w:tc>
<w:p>
<!-- Second cell contains the name of the node (from xml file) -->
<w:t>
<xsl:value-of select="NodeName"/>
</w:t>
</w:p>
</w:tc>
</xsl:for-each>
</w:tr>
</w:tbl>
</xsl:template>
也许我以一种完全错误的方式处理这个问题,但我最终把自己弄糊涂了,试图获得 1 张桌子,然后开始 for-each 循环。我将不胜感激任何建议/指导。