dom解析xml

来源:互联网 发布:注册自己域名的邮箱 编辑:程序博客网 时间:2024/05/18 01:27
? dom技术
public static void main(String[] args) throws ParserConfigurationException,
SAXException, IOException {
// 得到工厂类
DocumentBuilderFactory builderFactory = DocumentBuilderFactory
.newInstance();
// 得到解析器
DocumentBuilder builder = builderFactory.newDocumentBuilder();


Document document = builder.parse("src/main/java/myClass.xml");
// 测试
//NodeList nodeList = document.getElementsByTagName("学生");
Node node = document.getElementsByTagName("学生").item(0);
list(node);


? }
1. 所有的操作都是对myClass.xml的文件
<?xml version="1.0" encoding="utf-8" standalone="no"?><班级>
<学生 sex="男">
<名字>周星驰</名字>
<年龄>43</年龄>
<介绍>学习刻苦</介绍>
</学生>
<学生 sex="女">
<名字>林青霞</名字>
<年龄>32</年龄>
<介绍>是一个好学生</介绍>
</学生>


</班级>
2. 对文件进行遍历的代码
public static void list(Node node){

if(node.getNodeType()==Node.ELEMENT_NODE){
System.out.println("该节点名字是"+node.getNodeName());
}
NodeList nl=node.getChildNodes();
//遍历所有的子节点
for(int i=0;i<nl.getLength();i++){

Node node2=nl.item(i);
list(node2);
}
}
3. 读取某一个节点
//读取第一个学生的名字.
public static void read(Document doc){

//1.得到根元素 Element 是 Node 子类,它的能力比Node 强,
Element e=doc.getDocumentElement();
//2.得到学生节点对象
Element name=(Element) e.getElementsByTagName("名字").item(1);

System.out.println(name.getTextContent());
}
4. 读取属性


//读取属性
public static void readAttr(Document doc){
//得的根元素
Element root=doc.getDocumentElement();
//得到第二个学生节点对象
Element stu2=(Element) root.getElementsByTagName("学生").item(1);

String sexVal=stu2.getAttribute("sex");
System.out.println(sexVal);

}
5. 添加学生
//添加节点(添加学生)
public static void addNode(Document doc) throws TransformerException{
//创建一个元素节点. Element Node 
Element stu=doc.createElement("学生");
Element name=doc.createElement("名字");
name.setTextContent("贾宝玉");
stu.appendChild(name);
//把stu 挂到 根元素下
doc.getDocumentElement().appendChild(stu);
//更新文档
//1.得打TransformerFactory
TransformerFactory tff=TransformerFactory.newInstance();
//2.得到一个转化器
Transformer tf=tff.newTransformer();
//3.转化 
tf.transform(new DOMSource(doc), new StreamResult(new File("src/myClass.xml")));
}
6. 给某个元素添加属性
public static void addAttribute(Document doc) throws Exception{
//得到第三个学生的节点对象
Element e=(Element) doc.getElementsByTagName("学生").item(2);
e.setAttribute("sex", "男");//添加属性
//这是添加属性的第二种方法.
// Attr att=doc.createAttribute("sex2");
// att.setTextContent("女");
// e.setAttributeNode(att);
//更新
TransformerFactory tff=TransformerFactory.newInstance();
Transformer tf=tff.newTransformer();
tf.transform(new DOMSource(doc), new StreamResult(new File("src/myClass.xml")));
}
7. 删除节点
//删除一个学生
public static void delNode(Document doc) throws Exception{
//得到第三个学生的节点对象
Element e=(Element) doc.getElementsByTagName("学生").item(2);
//doc.getDocumentElement().removeChild(e);
//我们在删除某个节点的时候,可以通过 得打其父节点,然后将其删除.
e.getParentNode().removeChild(e);
TransformerFactory tff=TransformerFactory.newInstance();
Transformer tf=tff.newTransformer();
tf.transform(new DOMSource(doc), new StreamResult(new File("src/myClass.xml")));
}
8. 更新元素的内容
//修改学生信息 把周星驰的年龄在原来的基础+10;
public static void updNode(Document doc) throws Exception{
//得学生
Element e=(Element) doc.getElementsByTagName("年龄").item(0);
//取出年龄的值
String age=e.getTextContent();
int newAge=Integer.parseInt(age)+10;
e.setTextContent(newAge+"");
//更新xml
TransformerFactory tff=TransformerFactory.newInstance();
Transformer tf=tff.newTransformer();
tf.transform(new DOMSource(doc), new StreamResult(new File("src/myClass.xml")));
}