Dom4j的基本使用

1 篇文章 0 订阅

Dom4j的基本使用

一、下载对应的jar包

进入官网dom4j ->`地址,下载对应jdk版本的dom4j。
在这里插入图片描述

二、常用类的基本了解

对象说明
Document表示整个xml文档
Element标签
Attribute属性
Text文本内容

三、解析xml文件

3.1 准备一个Contact.xml

<?xml version="1.0" encoding="UTF-8"?>
<contactList>
    <contact id="1" vip="true">
        <name>   潘金莲  </name>
        <gender></gender>
        <email>panpan@itcast.cn</email>
    </contact>
    <contact id="2" vip="false">
        <name>武松</name>
        <gender></gender>
        <email>wusong@itcast.cn</email>
    </contact>
    <contact id="3" vip="false">
        <name>武大狼</name>
        <gender></gender>
        <email>wuda@itcast.cn</email>
    </contact>
    <user>
        <contact>
            <info>

                <name>我是西门庆</name>
            </info>
         </contact>
    </user>
</contactList>

3.2 创建测试类进行解析

测试使用的是junit包,如果没有导入包,直接在main里面执行此方法也行

首先把contact.xml放入src目录下,然后自己在src目录创建一个包,里面创建一个测试类,代码如下

package com.itheima.d1.dom4j;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.Test;

import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

public class Dom4jDemo2 {
    @Test
    public void parseToList() throws Exception {
        //1.创建解析器对象,解析xml.获取document
        SAXReader saxReader=new SAXReader();
        //加载xml  使用类加载资源的/可用直接定位到src
        InputStream is=Dom4jDemo2.class.getResourceAsStream("/Contacts2.xml");
        Document document = saxReader.read(is);
        //2.获取根元素
        Element rootElement = document.getRootElement();
        //3.获取所有的concat子元素
        List<Element> contactList = rootElement.elements("contact");
        //4.遍历子元素获取属性和值
        List<Contact> list=new ArrayList();
        for (Element element : contactList) {
            //不直接强转  直接解析成相关类型
            Integer id =Integer.valueOf( element.attributeValue("id"));
            Boolean vip =Boolean.valueOf( element.attributeValue("vip"));
            //再回去子元素的文本内容
            String name = element.elementTextTrim("name");
            String gender = element.elementTextTrim("gender");
            String email = element.elementTextTrim("email");
            Contact contact=new Contact(id,name,vip,gender,email);
            list.add(contact);
        }
        //5.输出 查看效果
        for (Contact contact : list) {
            System.out.println(contact);
        }
    }
}

3.3 输出 查看效果

在这里插入图片描述
四、总结

  1. SAXReader saxReader=new SAXReader(),这个类属于dom4j里面的,用于解析xml文件。
  2. 使用方法说明
方法属于类说明
Element getRootElement()Document获取根元素
List<Element> elements(标签名)Element获取所有指定的子元素
List<Element> elements()Element获取所有的子元素
Element element(标签名)Element获取指定的第一个子元素
String elementText(标签名)Element获取当前元素指定子元素的内容
String getName()Element获取标签名
String getText()Element获取元素的内容
String attributeValue(String name)Element获取元素指定属性名

子元素都是指一级子元素

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DOM和dom4j都是用于解析XML文档的工具,它们的使用方法略有不同。下面分别介绍DOM和dom4j解析XML使用方法: 1. 使用DOM解析XML 使用DOM解析XML时,需要按照以下步骤进行: ```java // 1. 创建 DocumentBuilderFactory 对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 2. 创建 DocumentBuilder 对象 DocumentBuilder builder = factory.newDocumentBuilder(); // 3. 通过 DocumentBuilder 解析 XML 文件,得到 Document 对象 Document document = builder.parse(new File("xml文件路径")); // 4. 获取根节点 Element root = document.getDocumentElement(); // 5. 获取子节点、属性节点等 NodeList nodeList = root.getElementsByTagName("节点名称"); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取子节点等操作 } else if (node.getNodeType() == Node.ATTRIBUTE_NODE) { Attr attribute = (Attr) node; // 获取属性节点等操作 } } ``` 2. 使用dom4j解析XML 使用dom4j解析XML时,需要按照以下步骤进行: ```java // 1. 读取 XML 文件 SAXReader reader = new SAXReader(); Document document = reader.read(new File("xml文件路径")); // 2. 获取根节点 Element root = document.getRootElement(); // 3. 获取子节点、属性节点等 List<Element> nodeList = root.elements("节点名称"); for (Element element : nodeList) { // 获取子节点等操作 List<Attribute> attributeList = element.attributes(); for (Attribute attribute : attributeList) { // 获取属性节点等操作 } } ``` 以上是DOM和dom4j解析XML基本使用方法。需要注意的是,使用DOM解析XML时,由于要将整个XML文档加载到内存中,因此对于大型XML文档,可能会出现内存溢出等问题。而dom4j相对于DOM,提供了更加方便的API和更高效的内存管理方式,因此在解析大型XML文档时,dom4j可能更加适合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值