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

大部分继续从这个问题: XSLT:CSV(或平面文件,或纯文本)到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(); 

Transformernet.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的function,比如在命名模板上启动转换的能力,我建议使用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)更快。