1

我正在尝试编写一个 XML 文件。我能够使用以下代码创建文档。我想将此文档写入具有缩进支持的文件。目前我的代码看起来像这样。

这是解析 XMl 和写入文件的更好技术。

public void writeXmlToFile(Document dom) throws IOException {
    OutputFormat format = new OutputFormat(dom);
    format.setIndenting(true);

    XMLSerializer serializer = new XMLSerializer ( new FileOutputStream(
                                 new File("sample.xml")), format);
    serializer.serialize(dom);
}

或者使用变压器是一种更好的方法。

public void writeXMLToFile(DOcument dom) throws TransformerException, IOException {
    TransformerFactory transFact = TransformerFactory.newInstance();
    Transformer        trans = transFact.newTransformer();

    trans.setOutputProperty(OutputKeys.ENCODING, "utf-8");
    trans.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "no");
    trans.setOutputProperty(OutputKeys.INDENT, "yes");
    trans.setOutputProeprty("{http://xml.apache.org/xslt}indent-amount", "2");

    StreamResult resut  = new StreamResult(new FileWriter(output));
    DOMSource source = new DOMSource(xmlDOC);

    trans.transform(source, result);
    writer.close();    
}

这两种方法有什么区别?哪些技术可以提供更好的性能?

4

1 回答 1

0

为了回答你的问题,我建议第三种方式,即 W3C 提出的 DOM Load and Save API。代码是不言自明的。

DOMImplementationLS ls = (DOMImplementationLS)
    DOMImplementationRegistry.newInstance().getDOMImplementation("LS");

// Gets a basic document from string.
LSInput input = ls.createLSInput();
String xml = "<bookstore city='shanghai'><a></a><b/></bookstore>";
InputStream istream = new ByteArrayInputStream(xml.getBytes("UTF-8"));
input.setByteStream(istream);
LSParser parser = ls.createLSParser(DOMImplementationLS.MODE_SYNCHRONOUS, null);
Document document = parser.parse(input);

// Creates a LSSerializer object and saves to file.
LSSerializer serializer = ls.createLSSerializer();
serializer.getDomConfig().setParameter("format-pretty-print", true);
LSOutput output = ls.createLSOutput();
OutputStream ostream = new FileOutputStream("c:\\temp\\foo.xml");
output.setByteStream(ostream);        
serializer.write(document, output);

与 XmlSerializer 或多或少是一个预标准不同,这种方法是首选的,因为它受到所有兼容实现的支持。不过,性能在很大程度上取决于供应商的实施。

于 2012-04-24T00:54:17.150 回答