大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
1.假如有下面的books.xml要用java dom4j解析查找。<?xml version=”1.0″ encoding=”UTF-8″?>
Lucene StudingDom4j TutorialsSpring in Action
O’Reilly
2.下面我们使用dom4j的xPath来解析:public void parseBooks(){
SAXReader reader = new SAXReader();
try {
Document doc = reader.read(“books.xml”);
Node root = doc.selectSingleNode(“/books”);
List list = root.selectNodes(“book[@url=’dom4j.com’]”);
for(Object o:list){
Element e = (Element) o;
String show=e.attributeValue(“show”);
System.out.println(“show = ” + show);
}
} catch (Exception e) {
e.printStackTrace();
}
}
3.代码详细解释如下:
Document doc = reader.read(“books.xml”);的意思是加载XML文档,此是可以用doc.asXML()来查看,它将打印整个xml文档。
Node root = doc.selectSingleNode(“/books”);是读取刚才加载的xml文档内的books节点下的所有内容,对于本例也是整个xml文档。
当然我们也可以加载/books下的某一个节点,如:book节点Node root = doc.selectSingleNode(“/books/book”);
或:Node root = doc.selectSingleNode(“/books/*”);
注意:如果有多个book节点,它只会读取第一个
root.asXML()将打印:
Lucene Studing
既然加载了这么多,那我怎么精确的查找得到我想要的节点呢,别急,看下面:List list = root.selectNodes(“book[@url=’dom4j.com’]”);
它的意思就是读取books节点下的book节点,且book的节点的url属性为dom4j.com
为什么使用list来接收呢,如果有两个book节点,且它们的url属性都为dom4j.com,此时就封闭到list里了。
如果想读取books下的所有book节点,可以这样:List list = root.selectNodes(“book”);
如果想读取books节点下的book节点下的title节点,可以这样:List list2 = root.selectNodes(“book[@url=’dom4j.com’]/title[@id=’123′]”);
注意:selectNodes()参数的格式:节点名[@属性名=’属性值’],如:book[@url=’dom4j.com’]
如果有多个节点,用“/”分开,如:book[@url=’dom4j.com’]/title[@id=’123′]
最近就是读取封闭在List里的内容了,可以用Node来读取,也可以用Element来转换(node可以强制转换成Element)。
attributeValue(“属性”)是读取该节点的属性值
getText()是读取节点的的内容。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/159401.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...