使用XSL在具有给定内容的标记之前获取所有标记

时间:2011-02-22 09:35:35

标签: xslt

也许有人带我一些建议如何纠正这个程序。我应该从+之前的字段编号中取出。有时这个字段出现在第17行(字段id 17),有时是14,19等等......其他字段也被填充。现在我的程序从字段ID 17中获取此数字。如何更正?

数据示例:

<document>
    <line id="0">
        <field id="0"><![CDATA[MAR5555]]></field>
        <field id="1"><![CDATA[12314124141241]]></field>
        <field id="2"><![CDATA[AAS]]></field>
        <field id="3"><![CDATA[FOR12312]]></field>
        <field id="4"/>
        <field id="5"/>
        <field id="6"/>
        <field id="7"/>
        <field id="8"/>
        <field id="9"/>
        <field id="10"/>
        <field id="11"/>
        <field id="12"/>
        <field id="13"/>
                <field id="14"/>
                <field id="15"/>
                <field id="16"/>
        <field id="17"><![CDATA[0072972+1313113123123]]></field>
        <field id="18"><![CDATA[5353]]></field>
        <field id="19"><![CDATA[444444]]></field>
        <field id="20"/>
        <field id="21"/>
    </line>
    <line id="1">
        <field id="0"><![CDATA[MAR6435]]></field>
        <field id="1"><![CDATA[car123]]></field>
        <field id="2"><![CDATA[sds]]></field>
        <field id="3"><![CDATA[fest]]></field>
        <field id="4"/>
        <field id="5"/>
        <field id="6"/>
        <field id="7"/>
        <field id="8"/>
        <field id="9"/>
        <field id="10"/>
        <field id="11"/>
        <field id="12"/>
        <field id="13"/>
        <field id="14"/>
        <field id="15"><![CDATA[0000062+0dadasd]]></field>
        <field id="16"><![CDATA[0d2]]></field>
        <field id="17"><![CDATA[cccc]]></field>
        <field id="18"/>
        <field id="19"><![CDATA[000000]]></field>
        <field id="20"/>
        <field id="21"/>
    </line>
    <line id="2">
        <field id="0"><![CDATA[MAR6435]]></field>
        <field id="1"><![CDATA[sss]]></field>
        <field id="2"><![CDATA[1231231]]></field>
        <field id="3"><![CDATA[45123]]></field>
        <field id="4"/>
        <field id="5"/>
        <field id="6"/>
        <field id="7"/>
        <field id="8"/>
        <field id="9"/>
        <field id="10"/>
        <field id="11"/>
        <field id="12"/>
        <field id="13"/>
        <field id="14"/>
        <field id="15"><![CDATA[0000062+0sdsd]]></field>
        <field id="16"><![CDATA[0f2]]></field>
        <field id="17"><![CDATA[843252dsd]]></field>
        <field id="18"/>
        <field id="19"><![CDATA[000000]]></field>
        <field id="20"/>
        <field id="21"/>
    </line> 
</document>

我的程序示例:

 <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:key name="kLine" match="line" use="substring-before(field[@id='17'],'+')"/>
        <xsl:template match="/*">
            <document>
                <xsl:apply-templates select="line[contains(field[@id='0'], 'MAR')][count(. | key('kLine', substring-before(field[@id='17'],'+'))[1]) = 1]"/> 
            </document>
        </xsl:template>
        <xsl:template match="line">
            <type-MAR>
                <document>
                    <xsl:value-of select="substring-before(field[@id='17'],'+')"/> 
                </document>
            </type-MAR>
        </xsl:template>
    </xsl:stylesheet>

结果:

<type-MAR>
 <document>
      0072972
 </document>
 <document>
      0000062          
 </document>
</type-MAR>

1 个答案:

答案 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:key name="kLine" match="line" use="
        substring-before(
            field[contains(., '+')]
            ,'+'
            )"/>
    <xsl:template match="/*">
        <document>
            <xsl:apply-templates select="
            line
                [contains(field[@id='0'], 'MAR')]
                [count(
                    . | key(
                        'kLine',
                        substring-before(
                            field[contains(., '+')]
                            ,'+')
                            )
                        [1]
                        ) = 1
                ]"/>
        </document>
    </xsl:template>
    <xsl:template match="line">
        <type-MAR>
            <document>
                <xsl:value-of select="
                    substring-before(
                        field[contains(., '+')],
                        '+'
                        )
                    "/>
            </document>
        </type-MAR>
    </xsl:template>
</xsl:stylesheet>

针对您的示例的格式良好的XML输出是:

<document>
    <type-MAR>
        <document>0072972</document>
    </type-MAR>
    <type-MAR>
        <document>0000062</document>
    </type-MAR>
</document>