Java - 提取子元素

时间:2015-09-16 08:35:03

标签: java xml xml-parsing

我是Java新手,需要解析下面的XML文件

<foo>
    <foo1>
        <tag1>1</tag1>
        <tag2>2</tag2>
    </foo1>

    <foo2>
        <element1>aaa</element1>
        <element1>bbb</element2>
    </foo2>

</foo>

我需要

<foo1>
    <tag1>1</tag1>
    <tag2>2</tag2>
</foo1>

<foo2>
    <element1>aaa</element1>
    <element1>bbb</element2>
</foo2>

作为输出。我能够获得节点的值但不是所需的输出。请帮帮我..谢谢。

2 个答案:

答案 0 :(得分:1)

好的,我想我明白了。这是包含文档的代码:

import java.io.*;
import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.*;
import javax.xml.transform.stream.*;
import org.w3c.dom.*;

    // parse input XML file into Document
    Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse("C://Temp/xx.xml");

    // build a formatted XML String 
    Transformer transformer = TransformerFactory.newInstance().newTransformer();
    transformer.setOutputProperty(OutputKeys.INDENT, "yes");
    StreamResult result = new StreamResult(new StringWriter());
    transformer.transform(new DOMSource(doc), result);
    String xmlString = result.getWriter().toString();

    // Split the formatted-XML-String according to new-line
    String lines[] = xmlString.split("\\r?\\n");
    // rebuild the String, skipping undesired lines
    xmlString = "" ;
    String newLine = String.format("%n");
    for (int i = 2 ; i < lines.length-1 ; i++) {
        xmlString += lines[i] + newLine;
    }
    System.out.println(xmlString);

答案 1 :(得分:0)

因为在您的情况下,您希望将无效的XML作为输出,我建议您不要解析XML文件。只需逐行读取整个文件,并通过跳过第一行和最后一行来构建所需的字符串