說到解析xml,相信大家都知道Android中的三中解析方式,這裏就不在多做介紹了,說一下最近剛剛用的dom4j吧,dom4j是一個Java的XML API,類似於jdom,用來讀寫XML文件的。dom4j是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一個開放源代碼的軟件。
使用Dom4j開發,需下載dom4j相應的jar文件
.官網下載: http://www.dom4j.org/dom4j-1.6.1/
得到文件解壓dom4j-1.6.1.jar,將jar包放入我們的項目中,在項目開發的過程中可以參考docs文件夾的(幫助文檔),找到index.html打開,點擊Quick start可以通過幫助文檔進行學習 dom4j進行xml的解析.
參考:http://blog.csdn.net/redarmy_chen/article/details/12969219
一、DOM4j中,獲得Document對象的方式有三種:
- 1.讀取XML文件,獲得document對象
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("csdn.xml"));
- 2.解析XML形式的文本,得到document對象.
- String text = "<csdn></csdn>";
- Document document = DocumentHelper.parseText(text);
- 3.主動創建document對象.
- Document document = DocumentHelper.createDocument(); //創建根節點
- Element root = document.addElement("csdn");
二、節點對象操作的方法
- 1.獲取文檔的根節點.
- Element root = document.getRootElement();
- 2.取得某個節點的子節點.
- Element element=node.element(“四大名著");
- 3.取得節點的文字
- String text=node.getText();
- 4.取得某節點下所有名爲“csdn”的子節點,並進行遍歷.
- List nodes = rootElm.elements("csdn");
- for (Iterator it = nodes.iterator(); it.hasNext();) {
- Element elm = (Element) it.next();
- // do something
- }
- 5.對某節點下的所有子節點進行遍歷.
- for(Iterator it=root.elementIterator();it.hasNext();){
- Element element = (Element) it.next();
- // do something
- }
- 6.在某節點下添加子節點
- Element elm = newElm.addElement("朝代");
- 7.設置節點文字. elm.setText("明朝");
- 8.刪除某節點.//childElement是待刪除的節點,parentElement是其父節點 parentElement.remove(childElment);
- 9.添加一個CDATA節點. Element contentElm = infoElm.addElement("content"); contentElm.addCDATA(“cdata區域”);
三、節點對象的屬性方法操作
- 1.取得某節點下的某屬性 Element root=document.getRootElement(); //屬性名name
- Attribute attribute=root.attribute("id");
- 2.取得屬性的文字
- String text=attribute.getText();
- 3.刪除某屬性 Attribute attribute=root.attribute("size"); root.remove(attribute);
- 4.遍歷某節點的所有屬性
- Element root=document.getRootElement();
- for(Iterator it=root.attributeIterator();it.hasNext();){
- Attribute attribute = (Attribute) it.next();
- String text=attribute.getText();
- System.out.println(text);
- }
- 5.設置某節點的屬性和文字. newMemberElm.addAttribute("name", "sitinspring");
- 6.設置屬性的文字 Attribute attribute=root.attribute("name"); attribute.setText("csdn");
四、將文檔寫入XML文件
- 1.文檔中全爲英文,不設置編碼,直接寫入的形式.
- XMLWriter writer = new XMLWriter(new FileWriter("ot.xml"));
- writer.write(document);
- writer.close();
- 2.文檔中含有中文,設置編碼格式寫入的形式.
- OutputFormat format = OutputFormat.createPrettyPrint();// 創建文件輸出的時候,自動縮進的格式
- format.setEncoding("UTF-8");//設置編碼
- XMLWriter writer = new XMLWriter(newFileWriter("output.xml"),format);
- writer.write(document);
- writer.close();
五、字符串與XML的轉換
- 1.將字符串轉化爲XML
- String text = "<csdn> <java>Java班</java></csdn>";
- Document document = DocumentHelper.parseText(text);
- 2.將文檔或節點的XML轉化爲字符串.
- SAXReader reader = new SAXReader();
- Document document = reader.read(new File("csdn.xml"));
- Element root=document.getRootElement();
- String docXmlText=document.asXML();
- String rootXmlText=root.asXML();
- Element memberElm=root.element("csdn");
- String memberXmlText=memberElm.asXML();
以上部分我們在網上都可以找到,下面列舉一個我自己寫的實例吧。我寫的是將字符串轉化爲xml在進行解析,並存入自定義實體,不需要單獨獲取節點存放到實體類。
先上xmlutils解析類,註釋都在裏面:
public class XMLUtils<T> {
public List<T> readXML(String XMLPathAndName, T t) {
List<T> list = new ArrayList<T>();//創建list集合
try {
// 獲取實體類的所有屬性,返回Field數組
Field[] field = t.getClass().getDeclaredFields();
//將字符串轉化爲xml
Document doc=DocumentHelper.parseText(XMLPathAndName);
//獲得根節點
Element node = doc.getRootElement();
Iterator<Element> it = node.elementIterator();
Element e ;
// 遍歷
for (Iterator i = it; i.hasNext();) {
// 獲取某個子節點對象
e= it.next();
//獲取實體類實例
t=(T)t.getClass().newInstance();
for (int j = 0; j < field.length; j++) {
// 獲取屬性的名字
String name = field[j].getName();
//將第一位轉化爲大寫,便於獲取實體類中set,get方法
name = name.substring(0, 1).toUpperCase() + name.substring(1);
//獲得set方法
Method m = t.getClass().getMethod("set" + name,String.class);
//e.elementText元素的某個指定的子元素中的text信息
m.invoke(t,e.elementText(field[j].getName().toUpperCase()));
}
list.add(t);
}
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
}
實體類:public class Bean {
private String result;
private String guester;
private String chinesename;
private String birthday;
private String idnumber;
private String nation;
private String address;
private String checkin;
private String checkout;
public String getResult() {
return result;
}
public void setResult(String result) {
this.result = result;
}
public String getGuester() {
return guester;
}
public void setGuester(String guester) {
this.guester = guester;
}
public String getChinesename() {
return chinesename;
}
public void setChinesename(String chinesename) {
this.chinesename = chinesename;
}
public String getBirthday() {
return birthday;
}
public void setBirthday(String birthday) {
this.birthday = birthday;
}
public String getIdnumber() {
return idnumber;
}
public void setIdnumber(String idnumber) {
this.idnumber = idnumber;
}
public String getNation() {
return nation;
}
public void setNation(String nation) {
this.nation = nation;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String getCheckin() {
return checkin;
}
public void setCheckin(String checkin) {
this.checkin = checkin;
}
public String getCheckout() {
return checkout;
}
public void setCheckout(String checkout) {
this.checkout = checkout;
}
}
xml
<RESULT>
<GUESTER>
<CHINESENAME>張三</CHINESENAME>
<BIRTHDAY>2000-01-01</BIRTHDAY>
<IDNUMBER>1234567890</IDNUMBER>
<NATION>漢</NATION>
<ADDRESS>北京</ADDRESS>
<CHECKIN>2000-01-01</CHECKIN>
<CHECKOUT>2000-01-01</CHECKOUT>
</GUESTER>
<GUESTER>
<CHINESENAME>李四</CHINESENAME>
<BIRTHDAY>2001-01-01</BIRTHDAY>
<IDNUMBER>9876543210</IDNUMBER>
<NATION>漢</NATION>
<ADDRESS>上海</ADDRESS>
<CHECKIN>2001-01-01</CHECKIN>
<CHECKOUT>2001-01-01</CHECKOUT>
</GUESTER>
</RESULT>
調用方法解析xml:
private List<Bean> list=new ArrayList<Bean>();
XMLUtils<Bean> b=new XMLUtils<Bean>();
list=b.readXML(xml, bean);
System.out.println(list.get(0).getAddress());
System.out.println(list.get(1).getAddress());
輸出結果:
至此解析完成。
當然解析xml文件也可以用這種方法。省略了我們一個個讀節點並放入實體中的部分,只需要定義自己的實體類調用即可。