使用dom4j查询,修改,删除xml

本文介绍如何使用DOM4J库进行XML文档的解析、查询、修改与回写操作,包括获取元素值、修改元素内容及使用XPath表达式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值