输入XML:
HugeXML.read xml, elements_lookup do |element|
# => element{ :name, :value, :attributes}
end
预期的XML输出:
<root>
<imageLink>
<url colNumber="1">aa</url>
<imageTypeCode colNumber="2">PRODUCT_IMAGE</imageTypeCode>
<languageCode colNumber="3">en</languageCode>
<languageCode colNumber="3">fr</languageCode>
</imageLink>
<imageLink>
<url colNumber="1">bb</url>
<imageTypeCode colNumber="2">PRODUCT_IMAGE</imageTypeCode>
<languageCode colNumber="3">fr</languageCode>
<commTest>
<languageCode colNumber="4">fssdr</languageCode>
<languageCode colNumber="4">fr</languageCode>
<dummy colNumber="5">DDDUMM</dummy>
</commTest>
<commTest>
<languageCode colNumber="4">fd777r</languageCode>
<languageCode colNumber="4">fr777</languageCode>
<dummy colNumber="5">DDD777UMM</dummy>
</commTest>
<changedName>
<languageCode colNumber="4">fd777r</languageCode>
<languageCode colNumber="4">fr777</languageCode>
<dummy colNumber="5">DDD777UMM</dummy>
</changedName>
</imageLink>
</root>
此过程发生在多个元素复杂度级别, 这些行号被分配,以便它以行和列的形式进入Excel工作表
任何人都可以帮助我吗?
答案 0 :(得分:1)
我不确定为什么编辑删除了XSLT 2.0标记,但作为两个嵌套级别的早期问题的后续跟踪我发布了这个XSLT 2.0样式表应该可以使用三个嵌套级别:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:strip-space elements="*"/>
<xsl:output indent="yes"/>
<xsl:template match="root">
<xsl:copy>
<xsl:apply-templates select="*[1]"/>
</xsl:copy>
</xsl:template>
<xsl:template match="root//*[*]">
<xsl:param name="row" select="1"/>
<xsl:variable name="copy" as="element()">
<xsl:copy>
<xsl:attribute name="rowNum" select="$row"/>
<xsl:apply-templates select="*[1]">
<xsl:with-param name="row" select="$row"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:variable>
<xsl:copy-of select="$copy"/>
<xsl:apply-templates select="following-sibling::*[1]">
<xsl:with-param name="row" select="max($copy/descendant-or-self::*[@rowNum]/@rowNum) + 1"/>
</xsl:apply-templates>
</xsl:template>
<xsl:template match="root/*//*[not(*)]">
<xsl:param name="row"/>
<xsl:variable name="index" as="xs:integer">
<xsl:number/>
</xsl:variable>
<xsl:variable name="copy" as="element()">
<xsl:copy>
<xsl:attribute name="rowNum" select="$row - 1 + $index"/>
<xsl:copy-of select="@*, node()"/>
</xsl:copy>
</xsl:variable>
<xsl:copy-of select="$copy"/>
<xsl:apply-templates select="following-sibling::*[1]">
<xsl:with-param name="row" select="$row"/>
</xsl:apply-templates>
</xsl:template>
</xsl:stylesheet>