使用xsl java将xml转换为csv

时间:2015-11-12 07:56:13

标签: java xml csv xslt

我关注this link 我想将xml转换为csv 我有一个xml,并为它编写和xsl 用href打开xml到Internet Explorer上的xsl工作 但是从this link运行代码会返回错误 无法解析名称空间前缀:xmlns

应该解决什么问题?

我有一个工作的xml& XSL

XML

  <?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>

XSL

   <?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>&#10;</xsl:text>
 </tr>
 </xsl:for-each>
 </table>
 </body>
 </html>
</xsl:template>
</xsl:stylesheet> 

java代码

从上面的链接运行java代码后

我收到错误

(Location of error unknown)org.xml.sax.SAXException: Can not resolve namespace prefix: xmlns
Exception in thread "main" java.lang.NullPointerException
    at org.apache.xalan.transformer.TransformerImpl.createSerializationHandler(TransformerImpl.java:1171)
    at org.apache.xalan.transformer.TransformerImpl.createSerializationHandler(TransformerImpl.java:1060)
    at org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1268)
    at org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1251)

1 个答案:

答案 0 :(得分:1)

  

应该解决什么问题?

要消除错误,您需要将其删除:

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的代表性样本。