Dom4j解析xml文檔
(一)、Dom4j解析xml文檔
Dom4j是一個簡單、靈活的開放源代碼的庫。Dom4j是由早期開發JDOM開發的。與JDOM不同的是,dom4j使用接口和抽象的人分離出來而后獨立基類,雖然Dom4j的API相對要復雜一些,但它提供了比JDOM更好的靈活性。
Dom4j是一個非常優秀的Java XML API,具有性能優異、功能強大和極易使用的特點。現在很多軟件采用的Dom4j,例如Hibernate,包括sun公司自己的JAXM也用了Dom4j。
使用Dom4j開發,需下載dom4j相應的jar文件。
(二)、DOM4j中,獲得Document對象的方式有三種:
1.讀取XML文件,獲得document對象
SAXReader reader = new SAXReader();
Document document = reader.read(new File("input.xml"));
2.解析XML形式的文本,得到document對象.
String text = "<members></members>";
Document document = DocumentHelper.parseText(text);
3.主動創建document對象.
Document document = DocumentHelper.createDocument();
//創建根節點
Element root = document.addElement("members");
(三)、獲取節點對象
1.獲取文檔的根節點.
Element root = document.getRootElement();
2.取得某個節點的子節點.
Element element=node.element(“書名");
3.取得節點的文字
String text=node.getText();
4.取得某節點下所有名為“member”的子節點,并進行遍歷.
List nodes = rootElm.elements("member");
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next();
}
5.對某節點下的所有子節點進行遍歷.
for(Iterator it=root.elementIterator();it.hasNext();){
Element element = (Element) it.next();
// do something
}
6.在某節點下添加子節點.
Element ageElm = newMemberElm.addElement("age");
7.設置節點文字.
element.setText("29");
8.刪除某節點.
//childElm是待刪除的節點,parentElm是其父節點
parentElm.remove(childElm);
利用dom4j修改 xml 文檔 舉例如下public class Demo03 {
/*
* 1、解析xml文檔,將xml文檔轉換Dom4j樹
* 2、利用dom4j樹提供的導航方法找到需要修改的節點
* 3、修改指定的節點,或者在指定的節點添加新的節點
* 4、寫入到dom4j樹document中,寫入修改后的xml文件中
* */
public static void main(String[] args)throws Exception{
//獲取讀取器
SAXReader reader = new SAXReader();
//reader.setStripWhitespaceText(true); //忽略空白
Document doc = reader.read(new File("src\\bk.xml"));
//獲取根元素
Element root =doc.getRootElement();
Element address = DocumentHelper.createElement("address");
address.setText("保定");
Element secord = (Element) root.elements("book").get(1);
List list = secord.elements();
list.add(2,address);
OutputFormat format = new OutputFormat(" ",true,"UTF-8");
XMLWriter xw = new XMLWriter(new FileWriter("src\\bk.xml"),format);
xw.write(doc);
xw.close();
}
}
(四)、節點對象屬性
1.取得某節點下的某屬性
Element root=document.getRootElement();
//屬性名name
Attribute attribute=root.attribute("size");
2.取得屬性的文字
String text=attribute.getText();
3.刪除某屬性
Attribute attribute=root.attribute("size");
root.remove(attribute);
3.遍歷某節點的所有屬性
Element root=document.getRootElement();
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
4.設置某節點的屬性和文字.
newMemberElm.addAttribute("name", "sitinspring");
5.設置屬性的文字
Attribute attribute=root.attribute("name");
attribute.setText("sitinspring")
public static void main(String[] args) throws Exception {
// 讀取器
SAXReader reader = new SAXReader();
// 讀取xml文檔 解析xml文檔
Document doc = reader.read(new File("src\\book.xml"));
// 獲取根據節點
Element root = doc.getRootElement();
System.out.println(root.getName());
parse(root);
}
// 解析元素
public static void parse(Element root) {
parseAttr(root);
for (Iterator<Element> it = root.elementIterator(); it.hasNext();) {
Element entity = it.next();
// 判斷是否只是文本
if (entity.isTextOnly()) {
parseAttr(entity);
System.out.println(entity.getText());
} else {
parse(entity);
}
}
}
// 解析元素的屬性
private static void parseAttr(Element root) {
for (Iterator<Attribute> it = root.attributeIterator(); it.hasNext();) {
Attribute entity = it.next();
System.out.println(entity.getName() + "--------------"
+ entity.getValue());
}
}
(五)、將節點寫入xml文件
1.文檔中全為英文,不設置編碼,直接寫入的形式.
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
2.文檔中含有中文,設置編碼格式寫入的形式.
OutputFormat format = OutputFormat.createPrettyPrint();
// 指定XML編碼
format.setEncoding("GBK");
XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);
writer.write(document);
writer.close();