如何在新行中显示每条记录?

时间:2014-07-02 21:25:04

标签: xml xslt

我尝试使用XSL输出XML文件中所有订单的列表,但值之间没有断行

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:key name="qty" match="quantity" use="id_order"/>  

<xsl:template match="/">
<output>
    <orders>

        <xsl:for-each select="output/orders/order"> 
            <order>

                <xsl:copy-of select="id|number|type|KG|PAL|M3"/>
                <xsl:for-each select="key('qty', id)">
                    <xsl:element name="{unit}">
                        <xsl:value-of select="value"/>  
                    </xsl:element>
                </xsl:for-each>
            </order>    
        </xsl:for-each>
    </orders>
</output>
</xsl:template>
<xsl:template match="quantity">
<amount><xsl:apply-templates select="node()|@*"/></amount>
</xsl:template>
</xsl:stylesheet>

如何在新行中显示每条记录?

这是我的xml

<?xml version= "1.0"?>
<?xml-stylesheet type="text/xsl" href="display.xls"?>
<output>
<orders>
    <order>
        <id>1</id>
        <number>10002</number>
        <type>Loading</type>
        <date>2013-01-01T02:30:00</date>
    </order>
    <order>
        <id>2</id>
        <number>10003</number>
        <type>Loading</type>
        <date>2013-01-01T010:30:00</date>
    </order>
    <order>
        <id>3</id>
        <number>10004</number>
        <type>Loaded</type>
        <date>2013-01-01T12:30:00</date>
    </order>
</orders>
<quantities>
    <quantity>
        <id_order>1</id_order>
        <unit>KG</unit>
        <value>1000</value>
    </quantity>
    <quantity>
        <id_order>1</id_order>
        <unit>PAL</unit>
        <value>3</value>
    </quantity>
    <quantity>
        <id_order>1</id_order>
        <unit>M3</unit>
        <value>1.5</value>
    </quantity>
    <quantity>
        <id_order>2</id_order>
        <unit>KG</unit>
        <value>2000</value>
    </quantity>
    <quantity>
        <id_order>2</id_order>
        <unit>PAL</unit>
        <value>4</value>
    </quantity>
    <quantity>
        <id_order>3</id_order>
        <unit>KG</unit>
        <value>5000</value> 
    </quantity>
</quantities>
</output>

我尝试用桌子做了些事但没有成功..

1 个答案:

答案 0 :(得分:0)

&#xa; or &#10;  =  LF character
&#xd; or &#13;  =  CR character

如果您的输出是xml,那么将以下行放在您需要的地方

<xsl:text>&#xa;</xsl:text>
or
<xsl:text>&#xd;&#xa;</xsl:text>