首页 > 开发 > Java > 正文

java编程之xpath介绍

2024-07-13 10:15:39
字体:
来源:转载
供稿:网友

一、使用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

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


注:相关教程知识阅读请移步到JAVA教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表