使用XSLT将XML输出到CSV的样式设置不正确
我有一个包含以下内容的xml文件使用XSLT将XML输出到CSV的样式设置不正确,xml,xslt,Xml,Xslt,我有一个包含以下内容的xml文件 <issues> <issue> <fieldvalue id="fld1">58</fieldvalue> </issue> <issue> <fieldvalue id="fld1">26</fieldvalue> <
<issues>
<issue>
<fieldvalue id="fld1">58</fieldvalue>
</issue>
<issue>
<fieldvalue id="fld1">26</fieldvalue>
</issue>
<issue>
<fieldvalue id="fld1">26</fieldvalue>
</issue>
但是,我得到的是问题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>
</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>
</xsl:text></xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:template>
,
;
,
;
非常感谢您的帮助,因为我了解这个问题。问题和字段位于同一父元素下。 我们已逐个填充字段名和发布值 XSL:
您的XML不完整。请编辑您的问题并包含缺少的数据。还包括您的完整样式表-从您发布的模板中,没有足够的上下文信息来帮助解决您的问题。请根据您的便利添加逗号和position()=last(),通过添加您建议的内容来实现。非常感谢。
<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>
</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>
</xsl:text></xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:template>
<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>
</xsl:text>
<xsl:value-of select="./fieldvalue"/>
<xsl:text>
</xsl:text>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
<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