package cn.itcast.xpath;
import java.io.InputStream;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
public class TestXPath2 {
public static void main(String[] args) throws Exception {
InputStream is = TestXpath.class
.getResourceAsStream("/cn/itcast/xpath/person.xml");
Document doc = new SAXReader().read(is);
String xpath = "";
// 选取节点
xpath = "person-list";// 在当前元素下的<person-list>元素
xpath = "./person-list";// 和上面的方式是等价的
xpath = "/person-list";// 和上面的方式等价的
xpath = "*";// 当前元素下的所有子元素
xpath = "/person-list/person";// 根元素下面的<person>子元素
xpath = "/person-list//person";// 根元素下的<person>后代元素
xpath = "//person";// 文档的所有<person>元素
xpath = "//@*";// 文档的所有属性节点@特制属性节点
// 添加限定语 ,使用中括号 [ ]
xpath = "//person[@id='002']";// 在所有<person>元素下面查找属性值为‘002’的元素
xpath = "/person-list/person[1]";// 根元素下面的第一个<person>元素
xpath = "/person-list/person[last()]";
xpath = "//person[position()<2]";// 第一个person元素
xpath = "//person[@id]";// 包含id名称属性的所有<person>。找什么样的元素?
// xpath = "//person[]";//非法,一定给条件
// 使用通配符
xpath = "/*";// 当前元素下的所有子元素
xpath = "/person-list/*";
xpath = "//*";// 文档的所有元素
xpath = "//person/@id";// <person>元素下的id的属性节点。找什么样的属性?
xpath = "//node()";
xpath = "//text()";
xpath = "//comment()";
// 使用关系运算符和算术运算符
xpath = "//person[@id='001' and @age='110']";// id属性值为001和age属性值为110的<person>元素
xpath = "//person[@id='001' and gender='女']";// id属性值为001和gender为女的<person>元素
xpath = "/person-list/person[last()-1]";// 根元素下面的倒数第二个person元素
List<Node> nList = doc.selectNodes(xpath);
// Node selectSingleNode = doc.selectSingleNode(xpath);
for (Node n : nList) {
System.out.println(n);
}
}
}
<pre name="code" class="html"><?xml version="1.0" encoding="UTF-8"?>
<person-list>
<!-- 这是注释 -->
<person id="001" age="110">
<name>
张三疯
</name>
<phone>13908999999</phone>
<gender>男</gender>
</person>
<person id="002" age="110">
<name>
小珊珊
</name>
<phone>13900000000</phone>
<gender>男</gender>
</person>
<hello>
</hello>
</person-list>