Dom4j和XPath的XML解析技术
程序员文章站
2022-05-28 21:08:59
...
dom4j技术进行查询操作.
使用步骤:
1.导入jar包
2.创建一个核心对象 SAXReader
new SAXReader();
3.将xml文档加载到内存中形成一棵树
Document doc=reader.read(文件)
4.获取根节点
Element root=doc.getRootElement();
5.通过根节点就可以获取其他节点(文本节点,属性节点,元素节点)
获取所有的子元素
List<Element> list=root.elements()
获取元素的指定属性内容
String value=root.attributeValue("属性名");
获取子标签标签体:遍历list 获取到每一个子元素
String text=ele.elementText("子标签名称")
xpath解析技术:(扩展)
依赖于dom4j
使用步骤:
1.导入jar包(dom4j和jaxen-1.1-beta-6.jar)
2.加载xml文件到内存中
3.使用api
selectNode("表达式");
selectSingleNode("表达式");
表达式的写法:
/ 从根节点选取
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
例如一个标签下有一个id属性且有值 id=2;
//元素名[@属性名='属性值']
//元素名[@id='2']
package com.dom4j;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Dom4jDemo {
public static void main(String[] args) throws Exception {
//创建核心对象
SAXReader reader = new SAXReader();
//获取dom树
Document doc = reader.read("E:\\SSD\\Java\\day08\\xml\\web.xml");
//获取根节点
Element root = doc.getRootElement();
//获取其他节点
List<Element> list = root.elements();
//遍历集合
for (Element ele : list) {
//获取servlet-name的标签体
String text = ele.elementText("servlet-name");
//System.out.println(text);
//获取url-pattern标签体
System.out.println(ele.elementText("url-pattern"));
}
//获取root的version属性值
String version = root.attributeValue("version") ;
System.out.println(version);
}
}
package com.xpath;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class XpathDemo {
public static void main(String[] args) throws DocumentException {
// 加载树
Document doc = new SAXReader().read("E:\\SSD\\Java\\day08\\xml\\web.xml") ;
// 获取节点
List<Element> list = doc.selectNodes("/web-app/servlet/servlet-name") ;
//Element ele = list.get(0) ;
Element ele = (Element) doc.selectSingleNode("//servlet/servlet-name") ;
System.out.println(ele.getText());
}
}
上一篇: 生日面怎么做既地道又好吃
下一篇: jQuery中的DOM操作