DOM是把XML整个文件都载入到内存,生成一个树,然后通过遍历来获取需要的标签及对应的值。
对于需要遍历所有节点的话,这样做速度会比较快,一次载入就可以了。
如果是只关心其中的某个节点,那这样的效率是很低的。
接下代码如下:
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.PrintWriter;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
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;
import com.zhouxf.javabase.xml.XmlDocument;
public class DomXmlDocument implements XmlDocument {
private Document document;
public void init() {
try {
DocumentBuilderFactory factory = DocumentBuilderFactory
.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
this.document = builder.newDocument();
} catch (ParserConfigurationException e) {
System.out.println(e.getMessage());
}
}
public void createXml(String fileName) {
// 创建根目标标签
Element root = this.document.createElement("users");
this.document.appendChild(root);
// 创建子标签
Element employee = this.document.createElement("user");
Element name = this.document.createElement("name");
name.appendChild(this.document.createTextNode("zhouxf"));
employee.appendChild(name);
Element age = this.document.createElement("age");
age.appendChild(this.document.createTextNode("29"));
employee.appendChild(age);
root.appendChild(employee);
// 创建转换源数据为树数据的工具的工厂
TransformerFactory tf = TransformerFactory.newInstance();
try {
// 获取一个转化工具
Transformer transformer = tf.newTransformer();
DOMSource source = new DOMSource(document);
transformer.setOutputProperty(OutputKeys.ENCODING, "utf-8");
// 是否允许空格
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
// 输出文件
PrintWriter pw = new PrintWriter(new FileOutputStream(fileName));
StreamResult result = new StreamResult(pw);
// 转换输出结果
transformer.transform(source, result);
System.out.println("生成XML文件成功!");
} catch (TransformerConfigurationException e) {
System.out.println(e.getMessage());
} catch (IllegalArgumentException e) {
System.out.println(e.getMessage());
} catch (FileNotFoundException e) {
System.out.println(e.getMessage());
} catch (TransformerException e) {
System.out.println(e.getMessage());
}
}
public void parserXml(String fileName) {
try {
// 创建build 工厂
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
// 通过工厂创建一个builder
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse(fileName);
Element documentElement = document.getDocumentElement();
NodeList users = documentElement.getChildNodes();
// NodeList users = document.getChildNodes();
for (int i = 0; i < users.getLength(); i++) {
Node user = users.item(i);
NodeList userInfo = user.getChildNodes();
for (int j = 0; j < userInfo.getLength(); j++) {
Node node = userInfo.item(j);
NodeList userMeta = node.getChildNodes();
for (int k = 0; k < userMeta.getLength(); k++) {
System.out.println(userMeta.item(k).getNodeName() + ":"
+ userMeta.item(k).getTextContent());
}
}
}
System.out.println("解析完毕");
} catch (FileNotFoundException e) {
System.out.println(e.getMessage());
} catch (ParserConfigurationException e) {
System.out.println(e.getMessage());
} catch (SAXException e) {
System.out.println(e.getMessage());
} catch (IOException e) {
System.out.println(e.getMessage());
}
}
}
public class DomTest {
public static void main(String[] args) {
DomXmlDocument document = new DomXmlDocument();
URL resource = DomTest.class.getClassLoader().getResource(
"./xml/test.xml");
try {
if (resource != null) {
System.out.println(resource.toURI().getPath());
document.parserXml(resource.toURI().getPath());
} else {
System.out.println("null..........");
}
} catch (URISyntaxException e) {
e.printStackTrace();
}
}
}
xml很简单:
<?xml version="1.0" encoding="UTF-8"?>
<users>
<user>
<name>
zhouxf
</name>
<age>
28
</age>
</user>
</users>
分享到:
相关推荐
DOM解析XML文件例子DOM解析XML文件例子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 实例 介绍w3c中的元素的用法,以及在解析xml过程中用到的API进行详细解释
用dom解析xml文件
在Java平台中如何来使用DOM解析xml文件,
DOM解析XML应用实例(入门经典案例),直接在Myeclipse值导入即可运行
android为我们提供了多种解析方式,DOM解析,代码操作简单,一直为解析xml文件的一个不错的选择
Android使用Dom方式解析XML,虽然xml文件太大时不建议用dom方式解析,但是如果文件比较小,也不失为一种选择。项目中xml放在assets文件夹下,view绑定使用butterknife
dom解析XML dom解析XML dom解析XMLdom解析XML dom解析XML
DOM解析XML 创建XML
使用dom解析XML,演示了如何使用DOM的五个基本对象来解析xml。
java学习笔记——使用DOM解析XML和使用SAX解析XML
DOM解析XML文档DOM解析XML文档DOM解析XML文档
包括android代码实例以及个人对Dom解析xml文件的总结文档。
以一个实例来说明DOM解析XML文件的方法与过程。
很实用的一个dom解析xml实例,很容易上手
完整的Oracle xmldom解析xml入参,经过测试,可以解析,成功入到数据表中。
使用DOM解析XML
DOM解析XML
android上使用DOM解析XML的简单示例。android4.0以上。