使用XSLT将XML输出为CSV并未正确设置样式

时间:2014-06-04 18:16:26

标签: xml xslt

我有一个带有以下

的xml文件
    <issues>
          <issue>
             <fieldvalue id="fld1">58</fieldvalue>
         </issue>
          <issue>
                <fieldvalue id="fld1">26</fieldvalue>
          </issue>
          <issue>
                <fieldvalue id="fld1">26</fieldvalue>
          </issue>

字段值的数字应该都是问题ID,如此

Issue ID
 58
 Issue ID
 26
 Issue ID
 31

但我得到的问题是id的/ fieldvalue id的水平名称,而不是名称问题ID

Issue ID     Subject  Submitted By
    58          26       31

我的xslt包含此

<xsl:strip-space elements="*"/>

<xsl:template match="fields">
    <xsl:for-each select="field">
        <xsl:value-of select="normalize-space(field_name)"/>
        <xsl:choose>
            <xsl:when test="position() != last()">,</xsl:when>
            <xsl:otherwise><xsl:text>&#xD;&#xA;</xsl:text></xsl:otherwise>
        </xsl:choose>
    </xsl:for-each>
</xsl:template>

<xsl:template match="issues">
    <xsl:for-each select="issue">
        <xsl:value-of select="fieldvalue/text()"/>
        <xsl:choose>
            <xsl:when test="position() != last()">,</xsl:when>
            <xsl:otherwise><xsl:text>&#xD;&#xA;</xsl:text></xsl:otherwise>
        </xsl:choose>
    </xsl:for-each>
</xsl:template>

非常感谢任何帮助

1 个答案:

答案 0 :(得分:0)

我明白了问题。问题和字段位于相同的父元素下。 我们逐个填充字段名称和问题值。

XSL:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  xmlns:exsl="http://exslt.org/common" version="1.0" exclude-result-prefixes="exsl">
  <xsl:output method="text"/>
  <xsl:strip-space elements="*"/>
   <xsl:template match="*">
     <xsl:for-each select="//issues/issue">
        <xsl:variable name="pos" select="position()"></xsl:variable>
        <xsl:value-of select="../../fields/field[position()=$pos]"/>
        <xsl:text>&#xA;</xsl:text>
        <xsl:value-of select="./fieldvalue"/>
        <xsl:text>&#xA;</xsl:text>           
    </xsl:for-each>
  </xsl:template>
</xsl:stylesheet>

用于上述XSL的XML:

<xml>
<issues>
<issue>
    <fieldvalue id="fld1">58</fieldvalue>
</issue>
<issue>
    <fieldvalue id="fld1">26</fieldvalue>
</issue>
<issue>
    <fieldvalue id="fld1">31</fieldvalue>
</issue>
</issues>
<fields>
    <field>
        <field_name id="fld1">Issue ID</field_name>
    </field>
    <field>
        <field_name id="fld1">Subject</field_name>
    </field>
    <field>
        <field_name id="fld1">Submitted By</field_name>
    </field>
</fields>
</xml>

输出:

Issue ID
58
Subject
26
Submitted By
31