Java中的Saxon:用于CSV到XML的XSLT

大部分时间都是从这个问题继续: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)更快.

上一篇:shopify好做吗 怎么做?


下一篇:shopify