使用XSLT将XML转换为csv
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用XSLT将XML转换为csv相关的知识,希望对你有一定的参考价值。
我正在学习xslt。如果我从XML文件中删除所有前缀“oz:”,我将得到预期的输出。请让我知道如何解决它。
另外,请让我知道元素“Spec”中“Descriptor”和“type”的逻辑
预期的csv输出:
Item,Desc,Type,Origin
"100","nuts","Metal","USA"
"125","bolts","",""
"125","screw","",""
实际产量:
Item,Desc,Type,Origin
100nutsMetalUSA125bolts125screw
XML:
<?xml version='1.0' encoding='UTF-8'?>
<oz:listing xmlns:oz="abc:com.listing/itemData">
<oz:categ>
<oz:item>100</oz:item1>
<oz:desc>nuts</oz:desc>
<oz:Spec oz:Descriptor="Metal">
<oz:ID oz:type="Spec_Code">Metal</oz:ID>
</oz:Spec>
<oz:origin>USA</oz:origin>
</oz:categ>
<oz:categ>
<oz:item>125</oz:item1>
<oz:desc>bolts</oz:desc>
</oz:categ>
<oz:categ>
<oz:item>125</oz:item1>
<oz:desc>screw</oz:desc>
<oz:origin>CAN</oz:origin>
</oz:categ>
</oz:listing>
XSLT:
<?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" encoding="UTF-8"/>
<xsl:strip-space elements="*" />
<xsl:template match="/">
<xsl:text>Item,Desc,Type,Origin
</xsl:text>
<xsl:apply-templates/>
</xsl:template>
<xsl:template match="listing">
<xsl:for-each select="./categ">
"<xsl:value-of select="normalize-space(./item)"/>","<xsl:value-of select="normalize-space(./desc)"/>","<xsl:value-of select="normalize-space(./Spec)"/>","<xsl:value-of select="normalize-space(./origin)"/>"
<!-- Add a newline at the end of the record -->
<xsl:text>
</xsl:text>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
答案
您需要将abc:com.listing/itemData
命名空间绑定到XSLT中的前缀并在xpath中使用它。
在下面的例子中,我将它绑定到oz
前缀(就像输入XML),但我可以使用不同的前缀。只要它与同一个uri(abc:com.listing/itemData
)绑定。
有关命名空间如何在XML中工作的更多信息,请参阅http://www.jclark.com/xml/xmlns.htm。
例...
XSLT 1.0
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:oz="abc:com.listing/itemData">
<xsl:output method="text" encoding="UTF-8"/>
<xsl:strip-space elements="*"/>
<xsl:template match="/">
<xsl:text>Item,Desc,Type,Origin
</xsl:text>
<xsl:apply-templates/>
</xsl:template>
<xsl:template match="oz:categ">
<xsl:value-of select="concat(
'"',oz:item,'",',
'"',oz:desc,'",',
'"',oz:Spec/@oz:Descriptor,'",',
'"',oz:origin,'"
')"/>
</xsl:template>
</xsl:stylesheet>
以上是关于使用XSLT将XML转换为csv的主要内容,如果未能解决你的问题,请参考以下文章
使用 Python 或 XSLT 将复杂的 XML 转换为 CSV