大部分时间都是从这个问题继续:XSLT: CSV (or Flat File, or Plain Text) to XML
所以,我从这里得到一个XSLT:http://andrewjwelch.com/code/xslt/csv/csv-to-xml_v2.html
它将CSV文件转换为XML文档.当在命令行上使用以下命令时,它会执行此操作:
java -jar saxon9he.jar -xsl:csv-to-xml.csv -it:main -o:output.xml
所以现在问题变成了:我如何在Java代码中执行此操作?
现在我的代码看起来像这样:
TransformerFactory transformerFactory = TransformerFactory.newInstance();
StreamSource xsltSource = new StreamSource(new File("location/of/csv-to-xml.xsl"));
Transformer transformer = transformerFactory.newTransformer(xsltSource);
StringWriter stringWriter = new StringWriter();
transformer.transform(documentSource, new StreamResult(stringWriter));
String transformedDocument = stringWriter.toString().trim();
(Transformer是net.sf.saxon.Controller的一个实例.)
命令行上的技巧是指定“-it:main”指向XSLT中的命名模板.这意味着您不必为源文件提供“-s”标志.
问题再次出现在Java方面.我在哪里/如何指定“-it:main”?不这样做会打破其他不需要指定的XSLT吗?我是否必须在每个XSLT文件中命名每个模板“main?”鉴于Transformer.transform()的方法签名,我必须指定源文件,那么这不能打败我在搞清楚这个问题时所取得的所有进展吗?
编辑:我发现s9api隐藏在saxon9he.jar中,如果有人正在寻找它.
解决方法:
您正在使用专为XSLT 1.0设计的JAXP API.如果你想利用XSLT 2.0的功能,比如在命名模板上启动转换的能力,我建议使用s9api接口,它更适合用于此目的.
但是,如果你有很多现有的JAXP代码并且你不想重写它,你通常可以通过将JAXP对象向下转换为底层的Saxon实现类来实现你想要的.例如,您可以将JAXP Transformer强制转换为net.sf.saxon.Controller,这样您就可以访问controller.setinitialTemplate();在调用transform()方法时,只需提供null作为Source参数.
顺便说一句,如果你正在编写需要2.0处理器的代码,那么我就不会使用TransformerFactory.newInstance(),这将为你提供它在类路径中找到的任何旧的XSLT处理器.使用新的net.sf.saxon.TransformerFactoryImpl()代替,(a)更健壮,(b)更快.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。