尝试编写一个XSLT 1.0模板,该模板将从Filemaker FMPXMLRESULT METADATA / @ NAME属性创建元素。这是XML示例:
<?xml version="1.0" encoding="UTF-16" ?>
<FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult">
<METADATA>
<FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Type" TYPE="TEXT"/>
<FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Level" TYPE="TEXT"/>
</METADATA>
<RESULTSET FOUND="2">
<ROW MODID="18" RECORDID="28133">
<COL><DATA>O1</DATA></COL>
<COL><DATA>L1</DATA></COL>
</ROW>
<ROW MODID="5" RECORDID="28153">
<COL><DATA>D12</DATA></COL>
<COL><DATA>L1</DATA></COL>
</ROW>
</RESULTSET>
</FMPXMLRESULT>
到目前为止,这是我的XLST进展:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fmp="http://www.filemaker.com/fmpxmlresult" exclude-result-prefixes="fmp">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="no"/>
<xsl:variable name="labels" select="fmp:FMPXMLRESULT/fmp:METADATA/fmp:FIELD/@NAME"/>
<xsl:template match="fmp:FMPXMLRESULT">
<FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult">
<PLAN>
<xsl:for-each select="fmp:RESULTSET/fmp:ROW">
<Sign>
<xsl:for-each select="fmp:COL">
<xsl:element name="{$labels[position()]}">
<xsl:value-of select="fmp:DATA"/>
</xsl:element>
</xsl:for-each>
</Sign>
</xsl:for-each>
</PLAN>
</FMPXMLRESULT>
</xsl:template>
</xsl:stylesheet>
我的麻烦在第13行:
<xsl:element name="{$labels[position()]}">
其中position()与fmp:COL的位置无关,可能与我使用它的方式毫无意义。
我想引用的是xsl:for-each循环中当前的fmp:COL元素,但我怀疑在我接近它的情况下无法在XLST 1.0中获得这个。
有没有人对如何继续提出建议或指示?
非常感谢!
查尔斯
答案 0 :(得分:1)
看看这个问题/答案。它可能就是你要找的东西。 Filemaker XSL Select Column By Name
更新: 这篇文章也有类似问题的很好的解决方案: XSLT question. How to pair field tags with data when original XML has them in separate sections?