一、使用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属性的//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介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

02-07 23:57