java解析XML學習總結——SAXReader解析xml文件數據


第一種方式:

1. 加入jar包

 

注意

    1.1 xml文件解析時編碼要一致(默認UTF-8),出現報錯可以在記事本中另存為來更改編碼格式。

     2.2 jar包兩個都需要

 

2.gao.xml數據如下:

<?xml version="1.0" encoding="UTF-8"?>
<emps>
    <emp>
        <id>1</id>
        <name>張三</name>
        <age>26</age>
        <gender></gender>
        <salary>3000</salary>
    </emp>
    <emp>
        <id>2</id>
        <name>李四</name>
        <age>21</age>
        <gender></gender>
        <salary>2000</salary>
    </emp>
    <emp>
        <id>3</id>
        <name>王五</name>
        <age>28</age>
        <gender></gender>
        <salary>6500</salary>
    </emp>
    <emp>
        <id>4</id>
        <name>趙六</name>
        <age>28</age>
        <gender></gender>
        <salary>5500</salary>
    </emp>
    <emp>
        <id>5</id>
        <name>錢七</name>
        <age>53</age>
        <gender></gender>
        <salary>12000</salary>
    </emp>
    <cmp department="總經辦">
        <id>007</id>
        <name>董事長</name>
        <age>52</age>
        <gender></gender>
        <salary>100000</salary>
    </cmp>
</emps>

3.XmlDemo.java代碼

package me.gorden.xml;
 
import java.io.File;
import java.util.List;
 
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
 
public class XmlDemo {
    public static void main(String[] args) {
        try {
            // 創建SAXReader
            SAXReader reader = new SAXReader();
            //從xml文件獲取數據  
            Document document = reader.read(new File("E:\\00_MeWockSpace\\MyEclipse 12\\xmlDemo\\src\\gao.xml"));
            // 獲取根節點 emps
            Element root = document.getRootElement();
            // 查找指定節點名稱QName的所有子節點elements
            List<Element> list = root.elements("emp");  //得到所有emp元素
            System.out.println("list==>"+list);
            
            for (Element element : list) { //循環輸出全部emp的相關信息  
                System.out.println("element.getName()==>"+element.getName());
                
                List<Element> list2 = element.elements(); //得到emp元素下的子元素
                
                for (Element e : list2) {  //遍歷emp元素下的子元素
                    System.out.print(e.getName()+":");  //獲取子元素名稱
                    System.out.print(e.getText()+" ");  //獲取子元素的文本值
                }
                 System.out.println();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

 

4.結果

list==>[org.dom4j.tree.DefaultElement@168afdd [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@1f21056 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@10e8647 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@91cf0b [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@b00ec2 [Element: <emp attributes: []/>]]
element.getName()==>emp
id:1 name:張三 age:26 gender:男 salary:3000 
element.getName()==>emp
id:2 name:李四 age:21 gender:女 salary:2000 
element.getName()==>emp
id:3 name:王五 age:28 gender:女 salary:6500 
element.getName()==>emp
id:4 name:趙六 age:28 gender:男 salary:5500 
element.getName()==>emp
id:5 name:錢七 age:53 gender:男 salary:12000

 

 

代碼解析:
1、讀取xml數據
SAXReader可以通過多種方式讀取xml數據,並返回Document格式的對象。通過查看源碼,可以看出read()方法接收File,InputStream和URL等格式的參數來讀取相應的xml數據。在代碼里我演示了讀取xml文檔和xml格式的字符串兩種方式。當然,字符串要根據相應的編碼轉成輸入流才能被SAXReader讀取。
2、解析xml數據
讀取到Document對象后,我們使用getRootElement()方法獲取根元素,返回的是一個Element對象。在本例中,該元素的name即為emps。
3、獲取子元素數據
獲取根元素后,便可以一層一層的去獲取他的子元素信息。如果知道子元素的標簽名稱,便可以直接調用element("name")方法獲取該子元素。如果不知道子元素的名稱,或者想直接獲取該元素下的全部子元素,可以調用elements()方法獲取一個包括全部元素的list,然后進行下一步的處理。
4、輸出元素信息
調用getName()方法獲取當前元素的元素名,attributeValue()獲取屬性名。如果當前元素沒有子元素,則調用getText()方法獲取元素值。

 

 

第二種方式:

1.ReadXml.java文件和上面的不一樣,其余的都是一樣的

package me.gorden.xml;
 
import java.io.File;
import java.util.List;
 
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
 
public class ReadXml {
    public static void main(String[] args) throws DocumentException {
        File file = new File("E:\\00_MeWockSpace\\MyEclipse 12\\xmlDemo\\src\\gao.xml");
        
        System.out.println("file===>"+file);
        // 創建SAXReader
        SAXReader reader = new SAXReader();
        // 用SAXReader來讀取文件,並轉換成Document
        Document document = reader.read(file);
        //用Document的selectNodes來讀取節點,返回list
        List<Object> list = document.selectNodes("/emps/emp/name");
        Element e = null;
        if(list.size()>0){
            e = (Element) list.get(0);
        }
        
        System.out.println("list.size()==>"+list.size());
        
        if(null != e){
            Object obj = e.getData();
            System.out.println("Element內容為:  "+obj);
        }else{
            System.out.println("Element內容為空");
        }
        
    }
}

 

2.結果

file===>E:\00_MeWockSpace\MyEclipse 12\xmlDemo\src\gao.xml
list.size()==>5
Element內容為:  張三

 

 

轉: https://blog.csdn.net/qq_36501591/java/article/details/80522531


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM