import java.io.*;
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;
/**
* @author Robin
*/
public class DomParseTest {
//(1)得到DOM解析器的工厂实例 //得到javax.xml.parsers.DocumentBuilderFactory;类的实例就是我们要的解析器工厂
DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
public DomParseTest() {
try {
//(2)从DOM工厂获得DOM解析器//通过javax.xml.parsers.DocumentBuilderFactory实例的静态方法newDocumentBuilder()得到DOM解析器
DocumentBuilder dombuilder = domfac.newDocumentBuilder();
//(3)把要解析的XML文档转化为输入流,以便DOM解析器解析它
InputStream is = new FileInputStream("c:\\hell.xml");
//(4)解析XML文档的输入流,得到一个Document 由XML文档的输入流得到一个org.w3c.dom.Document对象,以后的处理都是对Document对象进行的
Document doc = dombuilder.parse(is);
//(5)得到XML文档的根节点 在DOM中只有根节点是一个org.w3c.dom.Element对象。
Element root = doc.getDocumentElement();
//(6)得到节点的子节点
NodeList books = root.getChildNodes();
if (books != null) {
for (int i = 0; i < books.getLength(); i++) {
//这是用一个org.w3c.dom.NodeList接口来存放它所有子节点的,还有一种轮循子节点的方法,后面有介绍
Node book = books.item(i);
if (book.getNodeType() == Node.ELEMENT_NODE) {
//(7)取得节点的属性值 注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
String email = book.getAttributes().getNamedItem(
"email").getNodeValue();
System.out.println(email);
//(8)轮循子节点
for (Node node = book.getFirstChild(); node != null; node = node
.getNextSibling()) {
if (node.getNodeType() == Node.ELEMENT_NODE) {
if (node.getNodeName().equals("name")) {
// String name=node.getNodeValue(); 是一个空值。而
// String name1=node.getFirstChild().getNodeValue();
//才是真正的值,这是因为DOM把<name> rjzjh</name>也当作是两层结构的节点,
//其父节点为<name>节点本身,且它只有一个子节点(如果有属性的话就不止一个了!),
//子节点是它的值“rjzjh”,所以我们看到上面的结果。
String name = node.getNodeValue();// 是一个空值
String name2 = node.getTextContent();// 是一个空值
String name1 = node.getFirstChild()
.getNodeValue();
System.err.println(name);
System.out.println(name1);
System.out.println(name2);
}
if (node.getNodeName().equals("price")) {
String price = node.getFirstChild()
.getNodeValue();
System.out.println(price);
}
}
}
}
}
}
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
new DomParseTest();
}
}
分享到:
相关推荐
java dom 解析 xml 实例 介绍w3c中的元素的用法,以及在解析xml过程中用到的API进行详细解释
以一个实例来说明DOM解析XML文件的方法与过程。
一个项目同时用dom解析和sax解析xml文件貌似会报错,项目框架建一直是用sax和dom4j解析xml文件的。当我用dom解析xml文件。导入包后就报错识别不了xml文件的编码格式。于是做了一个sax解析xml文件的实例
解析javadom解析javadom解析javadom解析javadom解析
在Java平台中如何来使用DOM解析xml文件,
java dom解析xml <?xml version="1.0" encoding="UTF-8"?> <Head> <FileVersion>010000</FileVersion> <FileLength>00000CC3</FileLength> <FileTime>20100629173405</FileTime> <KeyIndex>1...
主要介绍了JAVA DOM解析XML文件过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
android为我们提供了多种解析方式,DOM解析,代码操作简单,一直为解析xml文件的一个不错的选择
JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML
DOM解析XML文件例子DOM解析XML文件例子DOM解析XML文件例子
java使用dom解析服务器端xml文件
java解析xml实例 java解析xml实例 java解析xml实例
dom4j解析xml实例,dom4j解析xml实例,dom4j解析xml实例,
java dom4 解析xml
java dom4j解析xml (详细注释)
通过dom4j解析xml,修改xml,自动生成xml文件。使用dom4j模拟解析web.xml配置文件,同时考虑到一个url-pattern和多个url-pattern的情况。
用java中的DOM解析器,解析XML文档,并实现一简单通讯录!
用dom解析xml文件
java dom4j 解析xml的例子,可用,另外内涵一个帮助类,其功能是:根据某个java工程中的文件名,获取这个文件在java工程中的绝对路径。解压加载到myeclipse上可用。
包括android代码实例以及个人对Dom解析xml文件的总结文档。