XML解析的二种方法:dom解析和sax解析
文件大小 存储位置 读取速度
dom解析 小文件 放在内存中 快
sax解析 大文件 硬盘中 慢 san解析是基于事件的
dom解析java代码
package com.huawei.xml;
import java.io.File;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
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;
public class TestXML {
/**
* 得到 classpath中的文件
*
*
*/
public static void main(String[] args) throws Exception{
/**
* 首先得到 当前类所在的类加载器路劲
*
* 然后在根据一个资源的名字去得到该资源的输入流 如果没有 则返回null
*/
InputStream in = TestXML.class.getClassLoader().getResourceAsStream("com/cdsxt/resources/Users.xml");
//System.out.println(in);
//得到dom解析的解析器
//得到解析器的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//通过工厂去得到解析器
DocumentBuilder builder = factory.newDocumentBuilder();
//将文件的输入流解析为一个Document
Document doc = builder.parse(in);
//调用
//parser(doc);
//getSibling(doc);
updateXML(doc);
}
public static void parser(Document document){
//得到文档的跟标签
Element root = document.getDocumentElement();
//根据元素名称去得到 元素集合
NodeList nodes = root.getElementsByTagName("User");
//遍历元素
for(int i=0;i<nodes.getLength();i++){
Node node = nodes.item(i);
//强转 一定要知道 当前的这个实例的实际类型是什么
Element ele = (Element) node;
//System.out.println(ele.getAttribute("id"));
/*System.out.println(node.getNodeName());
System.out.println(node.getNodeValue());
System.out.println(node.getNodeType());*/
//得到所有的子节点
NodeList childs = ele.getChildNodes();
for(int j=0;j<childs.getLength();j++){
//得到每一个孩子元素
Node c = childs.item(j);
//需要去除 差异性
if(c.getNodeType() == 1){
System.out.println(c.getTextContent());
}
}
}
}
public static void getSibling(Document document){
//Element root = document.getDocumentElement();
//Element lisi = document.getElementById("users1");
//root.
Element users = document.getDocumentElement();
//System.out.println(lisi.getNodeName());
//得到Users节点的第一个子节点
Node first = users.getFirstChild();
Node user = first.getNextSibling();
//System.out.println(users.getFirstChild().getNodeName());
while(user.getNodeType()!=1){
user = user.getNextSibling();
}
System.out.println(user);
}
/**
* 修改XML
* @param document
*/
public static void updateXML(Document document) throws Exception{
//创建一个节点
Element user = document.createElement("User");
//创建一个age节点
Element age = document.createElement("age");
age.setTextContent("40");
user.appendChild(age);
document.getDocumentElement().appendChild(user);
//创建一个 用于得到转换器的 工厂
TransformerFactory factory = TransformerFactory.newInstance();
//得到一个从源到目标的 转换器 Transformer
Transformer transformer = factory.newTransformer();
//构建源数据
DOMSource src = new DOMSource(document);
//得到类路径下面的file
String filename = TestXML.class.getClassLoader().getResource("com/cdsxt/resources/Users.xml").getFile();
//创建目标
//StreamResult target = new StreamResult(new File("D:\workspace\TestXML\src\com\cdsxt\resources\Users.xml"));
StreamResult target = new StreamResult(new File(filename));
//transformer.setOutputProperty(OutputKeys.ENCODING, "GBK");
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
transformer.transform(src, target);
}
}
User.xml
<?xml version="1.0" encoding="UTF-8"?>
<!--
这是xm注视
一个xml文档 只能有一个跟标签
关于声明信息 它的前面不允许出现任何字符
zhangsan 20 zhangsan@zhangsan.com it
-->
<Users>
<User id="lisi">
<username>lisi</username>
<age>20</age>
<email>lisi@lisi.com</email>
</User>
<User id="zhangsan">
<username>zhangsan</username>
<age>30</age>
<email>zhangsan@zhangsan.com</email>
</User>
<User>
<username>wangwu</username>
</User>
</Users>