如何使用XSLT获取XML元素的行号?

时间:2017-01-12 06:29:52

标签: xml xslt xslt-1.0

输入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工作表

任何人都可以帮助我吗?

1 个答案:

答案 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>