xml文档:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><person>
<p1>
<name>lqw</name>
<age>20</age>
<sex>nv</sex>
</p1>
<p1>
<name>pcl</name>
<age>26</age>
</p1>
</person>
要求:查询所有name元素里面的值
思路:
1.创建解析器;
2.得到document;
3.得到根节点:getRootElement()返回Element;
4.得到所有p1标签:
elements("p1"):返回list集合;遍历list得到1每一个p1;
5.得到name:element("name");
6.得到name里面的值:getText方法
代码:
package cn.itcast.jasptest;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class TestDom4j {
public static void main(String[] args) throws DocumentException {
selectName();
}
public static void selectName() throws DocumentException{
SAXReader saxReader=new SAXReader();
//得到document
Document document=saxReader.read("src/1.xml");
//得到根节点
Element root=document.getRootElement();
//得到所有p1
List<Element> list=root.elements("p1");
//遍历list
for (Element element : list) {
//element是每一个p1元素
//得到p1下面的name元素
Element name1=element.element("name");
//得到name里面的值
String s=name1.getText();
System.out.println(s);
}
}
}
要是想只得到第一个name的值,使用root.element("p1")得到第一个p1,再通过p1.element("name")得到name,再通过name1.getText()得到name的值;
要是想只得到第二个name的值,得到所有p1标签,然后通过list.get(1)得到第二个p1,其他步骤如上
//得到根节点
Element root=document.getRootElement();
//得到所有p1
List<Element> list=root.elements("p1");
Element p1=list.get(1);
Element name1=p1.element("name");
String s=name1.getText();
System.out.println(s);
要求:修改xml里面第一个p1下的age元素的值<age>3</age>
步骤:1,2,3同
4.得到第一个p1元素
5.得到第一个p1元素下的age
6.修改值为3:setText()方法
7.回写xml
代码:
package cn.itcast.jasptest;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;
import javax.print.Doc;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.xml.sax.DocumentHandler;
public class TestDom4j {
public static void main(String[] args) throws DocumentException, IOException {
addSex();
}
public static void addSex() throws DocumentException, IOException {
SAXReader saxReader=new SAXReader();
Document document=saxReader.read("src/1.xml");
Element root=document.getRootElement();
Element p1=root.element("p1");
Element age=p1.element("age");
age.setText("3");
OutputFormat format=OutputFormat.createPrettyPrint();
XMLWriter xmlWriter=new XMLWriter(new FileOutputStream("src/1.xml"),format);
xmlWriter.write(document);
xmlWriter.close();
}
}
要求:删除第一个p1下的age元素
步骤:
1,2,3,4,5步同
6.通过父节点删除:p1.remove(age);
7.回写
要求:使用dom4j获取xml第一个p1下的属性值
<p1 id1="lqw">
得到p1里面属性值:p1.attributeValue("id1");
打印输出
使用dom4j支持xpath:
首先引入支持xpath的jar包:jaxen-1.1-beta-6.jar
dom4j提供两个方法:
List selectNodes("xpath表达式"):获取符合表达式的所有节点的集合
Element selectSingleNode("xpath表达式"):获取符合表达式的一个节点
获取xml中所有name元素的值:
代码:
SAXReader saxReader=new SAXReader();
Document document=saxReader.read("src/1.xml");//得到document
List<Node> list=document.selectNodes("//name");//使用selectNodes(“//name”)方法得到所有name
元素
for(Node node:list) {
//node是每一个name元素
String s=node.getText();
System.out.println(s);
}
获取第一个p1下面的name的值:
//p1[@id1="lqw"]/name
代码:
SAXReader saxReader=new SAXReader();
Document document=saxReader.read("src/1.xml");
Node name=document.selectSingleNode("//p1[@id1='lqw']/name");
String s=name.getText();
System.out.println(s);