java编程之xpath介绍
作者:温良
一、使用dom4j支持XPATH的操作
—可以直接获取到某个元素,而不用一层一层的解析获取
XPATH如何使用:
第一种形式:/AAA/BBB/CCC,一个/代表一层,表示获取到AAA下面的BBB下面的CCC
第二种形式://BBB,表示和这个名称相同的都可以得到,只要名称是BBB都可以得到。//DDD/BBB:得到所有DDD下面的所有的BBB
第三种形式:/AAA/BBB/CCC/*,得到所有AAA下面BBB下面CCC下面的所有的元素。/*/*/*/BBB,表示限制前三层,前三层无论是什么名称都可以得到其下面的所有的BBB。//*,得到所有的元素。
第四种形式:/AAA/BBB[1],AAA下面的第一个BBB。/AAA/BBB[last()],表示得到AAA下面的最后一个BBB
第五种形式://@id,表示只要标签上有id属性都可以得到,得到所有有id属性的//BBB[@id],只要你BBB上有id属性都可以得到,得到有id属性的BBB
第六种形式://BBB[@id='b1'],得到含有属性id且值为b1的所有BBB
二、使用xpath
默认情况下,dom4j不支持xpath。
要想支持需要导入jar包,jaxen-1.1-beta-6.jar
有两个方法:selectNodes(“xpath标签表达式”);获得所有的元素,返回的是List,selectSingleNode(“xpath标签表达式”);获得一个元素,返回的是Node
1、查询xml中的所有name元素的值
步骤:获取document,使用方法selectNodes(“xpath标签表达式”);
public static void Test1() throws Exception { Document document = Dom4jUtils.getDocument(Dom4jUtils.PATH); List<Node> list = document.selectNodes("//name"); for (Node node : list) { //node是每一个元素具体的值 //得到每一个元素具体的值 String s = node.getText(); System.out.println(s); } }
2、查询xml中第一个name的值。步骤:先获取document,然后构建xpath表达式。
public static void Test2() throws Exception{ Document document = Dom4jUtils.getDocument(Dom4jUtils.PATH); Node name1 = document.selectSingleNode("//p1[@id1='aaa']/name"); //得到name的值 String s1 = name1.getText(); System.out.println(s1); }
二、案例分析
添加、删除、查询
student.xml
<?xml version="1.0" encoding="UTF-8"?> <student> <stu> <id>01</id> <name>zhangsan</name> <age>20</age> </stu> <stu> <id>02</id> <name>lisi</name> <age>19</age> </stu> </student>
student.java
package cn.qing.ov; public class Student { private String id; private String name; private String age; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getAge() { return age; } public void setAge(String age) { this.age = age; } @Override public String toString() { return "Student [id=" + id + ", name=" + name + ", age=" + age + "]"; } }
stuService.java
package cn.qing.service; import java.io.FileOutputStream; import java.io.Writer; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.Node; import org.dom4j.io.OutputFormat; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; import cn.qing.ov.Student; public class StuService { //增加 public static void addStu(Student student) throws Exception { SAXReader saxReader = new SAXReader(); Document document = saxReader.read("src/student.xml"); Element root = document.getRootElement(); //在根节点上添加stu Element stu = root.addElement("stu"); //在stu标签上一次添加id,name,age Element id1 = stu.addElement("id"); Element name1 = stu.addElement("name"); Element age1 = stu.addElement("age"); //在id,name,age,上依次添加值 id1.setText(student.getId()); name1.setText(student.getName()); age1.setText(student.getAge()); //回写到xml中 OutputFormat format = OutputFormat.createPrettyPrint(); XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/student.xml"),format); xmlWriter.write(document); xmlWriter.close(); } //删除,根据学生ID进行删除 /** * * @param id * @throws Exception * 1.创建解析器 * 2.获得document * 3.获取xml中的ID,使用xpath,返回一个list集合 * 4.遍历list,判断集合里的值是否和传进来的id相同 * 5.如果相同,把id所在的stu删除 * 6.回写 */ public static void delStu(String id) throws Exception { SAXReader saxReader = new SAXReader(); Document document = saxReader.read("src/student.xml"); List<Node> list = document.selectNodes("//id"); for (Node node : list) { String idv = node.getText(); //判断是否和传递的值相同 if(idv.equals(id)) { //得到stu的节点 Element stu = node.getParent(); //删除是通过父节点进行删除 Element student = stu.getParent(); student.remove(stu); } } OutputFormat format =OutputFormat.createPrettyPrint(); XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/student.xml"),format); xmlWriter.write(document); xmlWriter.close(); } //查询 public static Student selStu(String id) throws Exception { SAXReader saxReader = new SAXReader(); Document document = saxReader.read("src/student.xml"); List<Node> list = document.selectNodes("//id"); Student student = new Student(); for (Node node : list) { //node 是每一个id的值 String idv = node.getText(); if(idv.equals(id)) { Element stu = node.getParent(); String namev = stu.element("name").getText(); String agev = stu.element("age").getText(); student.setId(idv); student.setName(namev); student.setAge(agev); } } return student; } }
测试Test.java
package cn.qing.test; import cn.qing.ov.Student; import cn.qing.service.StuService; public class Test { public static void main(String[] args) throws Exception { //testAdd(); //testDel(); testSel(); } //测试添加方法 public static void testAdd() throws Exception { //创建student对象 Student stu = new Student(); stu.setId("03"); stu.setName("wangwu"); stu.setAge("18"); StuService.addStu(stu); } //测试删除方法 public static void testDel() throws Exception { StuService.delStu("03"); } //测试查询方法 public static void testSel() throws Exception { Student student = StuService.selStu("02"); System.out.println(student.toString()); } }
对于每一种类型,可以为其设置在不同的包,编程的思想
总结
以上就是本文关于java编程之xpath介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!