JAVAWEB第六天XPATH

来源:互联网 发布:淘宝大促活动 编辑:程序博客网 时间:2024/06/06 02:41

一、使用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());    }}

对于每一种类型,可以为其设置在不同的包,编程的思想

原创粉丝点击