1. 程式人生 > >java中使用Xpath讀取XML檔案資料

java中使用Xpath讀取XML檔案資料

package maven_test;

import java.io.FileInputStream;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class XpathDemo {

	public static void main(String[] args) {

		try {
			SAXReader reader = new SAXReader();

			Document doc = reader.read(new FileInputStream("myemp.xml"));
			String xpath = "/list/emp[salary>4000]/salary";
			/**
			 * /list/emp/name /list/emp/id[.>2]emp下id大於2的顯示
			 */
			List<Element> list = doc.selectNodes(xpath);

			for (Element ele : list) {
				System.out.println(ele.getName() + ":" + ele.getText());
			}
		} catch (Exception e) {

		}
	}

}

直接上程式碼!!!

Xpath路徑格式:

路徑表示式結果
bookstore選取 bookstore 元素的所有子節點。
/bookstore選取根元素 bookstore。
註釋:假如路徑起始於正斜槓( / ),則此路徑始終代表到某元素的絕對路徑!
bookstore/book選取屬於 bookstore 的子元素的所有 book 元素。
//book選取所有 book 子元素,而不管它們在文件中的位置。
bookstore//book選擇屬於 bookstore 元素的後代的所有 book 元素,而不管它們位於 bookstore 之下的什麼位置。
//@lang選取名為 lang 的所有屬性

例項:

路徑表示式
結果
/bookstore/book[1]

選取屬於 bookstore 子元素的第一個 book 元素。
/bookstore/book[last()]
選取屬於 bookstore 子元素的最後一個 book 元素。
/bookstore/book[last()-1]選取屬於 bookstore 子元素的倒數第二個 book 元素。
/bookstore/book[position()<3]選取最前面的兩個屬於 bookstore 元素的子元素的 book 元素。
//title[@lang]選取所有擁有名為 lang 的屬性的 title 元素。
//title[@lang='eng']選取所有 title 元素,且這些元素擁有值為 eng 的 lang 屬性。
/bookstore/book[price>35.00]選取 bookstore 元素的所有 book 元素,且其中的 price 元素的值須大於 35.00。
/bookstore/book[price>35.00]/title選取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值須大於 35.00。
萬用字元描述
*匹配任何元素節點
@*匹配任何屬性節點