使用xsl java将xml转换为csv
我在跟踪 我想将xml转换为csv 我有一个xml,并为此编写了xml和xsl 在internet explorer上使用href打开xml到xsl工作 但是从运行代码返回一个错误 无法解析命名空间前缀:xmlns 该怎么解决呢 我有一个有效的xml&xsl xml使用xsl java将xml转换为csv,java,xml,csv,xslt,Java,Xml,Csv,Xslt,我在跟踪 我想将xml转换为csv 我有一个xml,并为此编写了xml和xsl 在internet explorer上使用href打开xml到xsl工作 但是从运行代码返回一个错误 无法解析命名空间前缀:xmlns 该怎么解决呢 我有一个有效的xml&xsl xml <?xml version='1.0' encoding='utf-8'?> <?xml-stylesheet type="text/xsl" href="student2.xsl"?>
<?xml version='1.0' encoding='utf-8'?>
<?xml-stylesheet type="text/xsl" href="student2.xsl"?>
<rankings xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ign="http://api.DomainName.com/2.0" count="438" total="438" offset="0" xsi:schemaLocation="http://api.DomainName.com/2.0 http://api.DomainName.com/2.0/api.xsd" >
<ranking keyword="80s fancy dress">
<ranks>
<rank week="201526" country="uk" searchengine="google_uk_en">NR</rank>
<rank week="201527" country="uk" searchengine="google_uk_en">NR</rank>
<rank week="201528" country="uk" searchengine="google_uk_en">NR</rank>
<rank week="201529" country="uk" searchengine="google_uk_en">NR</rank>
<rank week="201530" country="uk" searchengine="google_uk_en">NR</rank>
<rank week="201531" country="uk" searchengine="google_uk_en">NR</rank>
</ranks>
</ranking>
</rankings>
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns="http://api.DomainName.com/2.0" exclude-result-prefixes=xmlns>
<xsl:output method="text" encoding="UTF-8" omit-xml-declaration="yes" indent="yes" />
<xsl:template match="/">
<html>
<body>
<table border="1">
<tr bgcolor="#9acd32">
</tr>
<xsl:for-each select="rankings/ranking/ranks/rank">
<tr>
<keyword><xsl:value-of select="../../@keyword"/></keyword>
<xsl:text>,</xsl:text>
<week><xsl:value-of select="@week"/></week>
<xsl:text>,</xsl:text>
<country><xsl:value-of select="@country"/></country>
<xsl:text>,</xsl:text>
<searchengine><xsl:value-of select="@searchengine"/></searchengine>
<xsl:text>,</xsl:text>
<rank><xsl:value-of select="../rank"/></rank>
<xsl:value-of select="." />
<xsl:text> </xsl:text>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
该怎么解决呢
要消除错误,您需要删除以下内容:
exclude-result-prefixes=xmlns
从xsl:stylesheet
标记。您还需要删除默认命名空间声明:
xmlns="http://api.DomainName.com/2.0"
否则,您的所有输出都将放在该名称空间中,如果您希望它是HTML,那么您肯定不希望发生这种情况
您还需要进行其他更改—例如,如果要输出HTML表,请将输出方法设置为“HTML”而不是“text”,并确保表结构有效
注意:
您的XML声明了一个命名空间:
xmlns:ign=”http://api.DomainName.com/2.0“
但此命名空间声明未在任何地方使用。因此,样式表可以忽略它。如果您向我们展示了真实XML的代表性示例。如果您希望.csv作为输出,为什么要使用?
xmlns="http://api.DomainName.com/2.0"