我正在尝试从表单的xml文件中创建一个csv:
<?xml version="1.0" encoding="UTF-8"?>
<Envelope>
<Header>
<env:MessageSentDateTime>2012-09-19T09:50:04Z</env:MessageSentDateTime>
<env:MessageSequenceNumber>856432</env:MessageSequenceNumber>
</Header>
<Body>
<Data>
<Data:ID>
<Data:AODB>9346280</Data:AODB>
<Data:Ref>
<common:Code>HJ</common:Code>
<common:num>8113</common:num>
</Data:Ref>
</Data:ID>
... Continues like this, no set number of nodes, parts or AnotherParts
</Body>
Second message starting with <Header> ending with </Body>,
will be more than 2 in practice
</Envelope>
我想在/ Body标签的csv文件中添加换行符,因为这表示有新消息。消息的混合将有不同数量的节点,不同数量的部分以及Body部分中没有一致的结束节点。另外,会有节点不包含任何文本,但我仍然想要一个逗号。
到目前为止,我有:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:strip-space elements="*"/>
<xsl:template match="*[not(*)]">
<xsl:value-of select="normalize-space(.)"/>
<xsl:text>,</xsl:text>
</xsl:template>
<xsl:template match="Body[last()]">
<xsl:value-of select="normalize-space(.)"/>
<xsl:text> </xsl:text>
</xsl:template>
</xsl:stylesheet>
它还在Body中的最后一条信息后面添加一个逗号。我想用换行符替换逗号,有没有一种简单的方法可以做到这一点?
此致 大卫
答案 0 :(得分:0)
一种方法可能是更改与 Body 元素匹配的模板,以专门查找“leaf”子元素
<xsl:template match="Body">
<xsl:apply-templates select=".//*[not(*)]"/>
<xsl:text> </xsl:text>
</xsl:template>
然后,在与叶元素匹配的模板中,如果它不是它找到的第一个元素,则可以将其更改为仅输出逗号
<xsl:if test="position() > 1">
<xsl:text>,</xsl:text>
</xsl:if>
如果你想给它一个完整的XSLT:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:strip-space elements="*"/>
<xsl:template match="*[not(*)]">
<xsl:if test="position() > 1">
<xsl:text>,</xsl:text>
</xsl:if>
<xsl:value-of select="normalize-space(.)"/>
</xsl:template>
<xsl:template match="Body">
<xsl:apply-templates select=".//*[not(*)]"/>
<xsl:text> </xsl:text>
</xsl:template>
</xsl:stylesheet>
答案 1 :(得分:0)
我的规格稍有变化,需要节点路径和值才能使每个条目都是唯一的。这是我用来解决问题的代码:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"></xsl:output>
<xsl:strip-space elements="*"/>
<xsl:template match="*[*]">
<xsl:param name="elementNames" select="''"/>
<xsl:apply-templates select="*">
<xsl:with-param name="elementNames">
<xsl:copy-of select="$elementNames"/>
<xsl:value-of select="replace(name(.), ':', '.')"/>
<xsl:text>_</xsl:text>
</xsl:with-param>
</xsl:apply-templates>
</xsl:template>
<xsl:template match="*[not (*)]">
<xsl:param name="elementNames" select="''"/>
<xsl:copy-of select="$elementNames"/>
<xsl:value-of select="replace(name(.), ':', '.')"/>
<xsl:value-of select="name()"/>,<xsl:apply-templates select="current()/text()"/>
<xsl:text> </xsl:text>
</xsl:template>
<xsl:template match="/*">
<xsl:apply-templates select="*"/>
</xsl:template>
</xsl:stylesheet>
感谢所有看过并试图提供帮助的人。
此致 大卫