ファイルが巨大でない限り、Java DOM パーサーを使用できます (DOM パーサーはファイルをメモリに保持します)。
ノード (ルートから開始) を指定すると、その子を列挙し、各子に対して同じ関数を再帰的に呼び出すことができます。
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class RecursiveDOM {
public static void main(final String[] args) throws SAXException, IOException, ParserConfigurationException {
new RecursiveDOM("file.xml");
}
public RecursiveDOM(final String file) throws SAXException, IOException, ParserConfigurationException {
final DocumentBuilderFactory dbfac = DocumentBuilderFactory.newInstance();
final DocumentBuilder docBuilder = dbfac.newDocumentBuilder();
final Document doc = docBuilder.parse(this.getClass().getResourceAsStream(file));
final List<String> l = new ArrayList<String>();
parse(doc, l, doc.getDocumentElement());
System.out.println(l);
}
private void parse(final Document doc, final List<String> list, final Element e) {
final NodeList children = e.getChildNodes();
for (int i = 0; i < children.getLength(); i++) {
final Node n = children.item(i);
if (n.getNodeType() == Node.ELEMENT_NODE) {
list.add(n.getNodeName());
parse(doc, list, (Element) n);
}
}
}
}
結果:
[FUNCTION, NAME, CALLS, FUNCTION, NAME, CALLS, FUNCTION, NAME, FUNCTION, NAME]