dom4j解析xml文档(增删查改)
2014-04-08 19:01
393 查看
package cn.itcast.dom4j;
import java.awt.print.Book;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.OutputStreamWriter;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test;
public class Demo1 {
//读取xml文档第二本书的,<书名>JavaScript网页开发</书名>
public void read() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element root = document.getRootElement();
Element book = (Element) root.elements("书").get(1);
String value = book.element("书名").getText();
System.out.println(value);
}
//读取xml文档第二本书的,<书名 name="xxx">JavaScript网页开发</书名>
public void read1() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element root = document.getRootElement();
Element book = (Element) root.elements("书").get(1);
String value = book.element("书名").attributeValue("name");
System.out.println(value);
}
//在第一本书上添加一个新的售价<售价>200元</售价>
public void add() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = document.getRootElement().element("书");
book.addElement("售价").setText("200元");
// OutputFormat format = OutputFormat.createCompactFormat();//紧凑的
// format.setEncoding("gb2312");
// XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream("src/book.xml"),"gb2312"),format);
//这样编码才不会乱码
XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream("src/book.xml"),"UTF-8"));
// XMLWriter writer = new XMLWriter(new FileWriter("src/book.xml"));
// 不管xml文档是什么编码保存的,都会乱码
writer.write( document );
writer.close();
}
//在第一本书上的指定位置添加一个新的售价<售价>200元</售价>
public void add2() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = document.getRootElement().element("书");
List list = book.elements();
Element price = DocumentHelper.createElement("售价");
price.setText("300元");
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
public void delete() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element price = document.getRootElement().element("书").element("售价");
price.getParent().remove(price);
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
//改
@Test
public void update() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = (Element) document.getRootElement().elements("书").get(1);
book.element("作者").setText("徐文艳");
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
}
import java.awt.print.Book;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.OutputStreamWriter;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.junit.Test;
public class Demo1 {
//读取xml文档第二本书的,<书名>JavaScript网页开发</书名>
public void read() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element root = document.getRootElement();
Element book = (Element) root.elements("书").get(1);
String value = book.element("书名").getText();
System.out.println(value);
}
//读取xml文档第二本书的,<书名 name="xxx">JavaScript网页开发</书名>
public void read1() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element root = document.getRootElement();
Element book = (Element) root.elements("书").get(1);
String value = book.element("书名").attributeValue("name");
System.out.println(value);
}
//在第一本书上添加一个新的售价<售价>200元</售价>
public void add() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = document.getRootElement().element("书");
book.addElement("售价").setText("200元");
// OutputFormat format = OutputFormat.createCompactFormat();//紧凑的
// format.setEncoding("gb2312");
// XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream("src/book.xml"),"gb2312"),format);
//这样编码才不会乱码
XMLWriter writer = new XMLWriter(new OutputStreamWriter(new FileOutputStream("src/book.xml"),"UTF-8"));
// XMLWriter writer = new XMLWriter(new FileWriter("src/book.xml"));
// 不管xml文档是什么编码保存的,都会乱码
writer.write( document );
writer.close();
}
//在第一本书上的指定位置添加一个新的售价<售价>200元</售价>
public void add2() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = document.getRootElement().element("书");
List list = book.elements();
Element price = DocumentHelper.createElement("售价");
price.setText("300元");
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
public void delete() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element price = document.getRootElement().element("书").element("售价");
price.getParent().remove(price);
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
//改
@Test
public void update() throws Exception{
SAXReader reader = new SAXReader();
Document document = reader.read("src/book.xml");
Element book = (Element) document.getRootElement().elements("书").get(1);
book.element("作者").setText("徐文艳");
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("UTF-8");
XMLWriter writer = new XMLWriter(new FileOutputStream("src/book.xml"));
writer.write(document);
writer.close();
}
}
相关文章推荐
- DOM4j 解析xml文档,完成增删改查
- dom4j解析xml文档(增删改查)
- xml文档解析之dom4j的增删改查 ,乱码问题
- Dom4j解析XML文档 —— 增删改查
- Dom4j解析xml文档实现增删改查
- java与xml之DOM4J生成和解析XML文档
- DOM4J解析XML文档
- XML解析(增删改查)-DOM解析(Jaxp、DOM4J实现DOM解析)、SAX解析(Jaxp实现SAX解析)
- Java 解析xml文档笔记(SAX,DOM,DOM4J)
- 使用dom4j解析、增删改xml文档,xPath技和SAX解析
- 解析XML文档方式之四:dom4j方式
- 使用SAX和dom4j解析XML文档
- Javaweb-xml编程-Dom4j解析xml文档
- Myeclipse下不用dom4j等解析xml文档
- XML文档解析之DOM4J解析
- dom4j解析及写入XML文档时的乱码问题
- 利用dom4j解析xml文档,自动遍历节点属性
- XML案例(使用DOM4J解析XML文档)
- dom4j解析xml文档
- Dom 解析xml文档,实现xml文档结点的增删改查,遍历