您的位置:首页 > 其它

DOM 解析XML文件

2013-09-06 09:28 190 查看
package org.chapter.xml;

import java.io.File;

import java.io.IOException;

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 FirstTest {

public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {

//构建文档工厂

DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();

//通过工厂构建文档结构

DocumentBuilder builder=factory.newDocumentBuilder();

//构建文档

Document document=builder.parse(new File("src\\student.xml"));

//获取文档根元素

Element rootElement= document.getDocumentElement();

//获取当前文档的标签名称

String rootElelmentTagName=rootElement.getTagName();

//这里打印出来的是person标签

// System.out.println(rootElelmentTagName);

//获取该文档下面的所有子节点

NodeList childNodes=rootElement.getChildNodes();

//查看子节点的大小

int length= childNodes.getLength();

//这里打印的节点长度是 5

// System.out.println(length);

for (int i = 0; i < childNodes.getLength(); i++) {

//获取到当前的子节点

Node childNode=childNodes.item(i);

/***

* 打印当前节点的名称 结果是:

* #text

student

#text

student

#text 这里也解释了 为什么length=5

*/

// System.out.println(childNode.getNodeName());

if(childNode instanceof Element){

NodeList childs=childNode.getChildNodes();

for (int j = 0; j < childs.getLength(); j++) {

Node child=childs.item(j);

if(child instanceof Element){

Element e=(Element) child;

System.out.println(e.getTagName()+":"+e.getTextContent()+":"+e.getAttribute("id"));

}

}

}

}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: