Java使用dom4j解析xml、读取xml文件图文教程
作者:大学生自救指南
技能分析:解析XML
使用DOM4J解析XML文档的步骤:
Dom4j 是一个开源的 XML 解析框架,它基于 Java 的 sax 解析器和 jaxp 解析器开发,提供了灵活简便、性能优良、扩展性强的 XML 解析和生成功能。
Dom4J通过SAXReader对象加载并解析xml文件,把它转换为内存中的Document对象,接着对Document对象中的元素进行添加、更新和删除操作,并且通过XMLWriter对象把修改后的Document对象保存到xml文件中。
帮助手册:Overview (dom4j 1.6.1 API)

Dom4j核心对象
1.SAXReader:xml解析器
(1)创建SASXReader对象,无参构造方法
(2)调用read(xml文件资源),读取并解析xml,得到Document对象
2.Document:xml文档
调用ELement getRootELement() 得到 根标签对象
3.ELement:
(1)获取第一个子标签:Element element(标签名)
(2)获取所有子标签:List elements(标签名)
(3)获取属性:Attribute attribute(属性名)
(4)获取标签的内容:elementText()
(5)获取属性的值:attributeValue()
配置Dom4j的jar包
1.在项目根目录下创建lib文件夹
2.将dom4j.jar拷贝到lib目录下

3. 点击Project Structure

4.再点击Libraries,点击“+”,添加Java

5.进入Select Library Files界面,点击lib文件夹

6.添加后,点击左下角Apply,再点应用,就完成了

读取xml文件
(1)创建SAX解析器SAXReader对象,用于读取xml文件
SAXReader saxReader = new SAXReader();
(2)读取xml文件,得到Document对象:
Document document = saxReader.read("User.xml");
注:若read下有红色波浪线,则直接alt+enter抛异常即可
(3) 通过Document对象获取根元素
Element rootElement = document.getRootElement();
(4)通过父元素获取子元素:
获取迭代器:elementIterator(),迭代获取。
指定元素名:element(元素名) 获取指定元素名的第一个子元素
获取指定元素: elements(元素名) List 指定元素名的所有的子元素
(5)通过元素获取它的属性:
获取迭代器:attributeIterator(),迭代获取。
指定索引(0开始)或名字:attribute(索引)、attribute(属性名)
读取User.xml文件
<?xml version="1.0" encoding="utf-8"?>
<users>
    <user userId="1">
        <username>admin</username>
        <pwd>123</pwd>
    </user>
    <user userId="2">
        <username>lisi</username>
        <pwd>123</pwd>
    </user>
</users>src.demo1文件:
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import java.util.List;
public class demo1 {
    public static void main(String[] args) throws DocumentException {
        SAXReader saxReader = new SAXReader();
        Document document = saxReader.read("User.xml");
        Element rootElement = document.getRootElement();
        //打印根标签名字
        System.out.println("标签名:"+rootElement.getName());
        List<Element> userElements = rootElement.elements("user");
        for(Element userEle:userElements){
            //子标签
            Element usernameEle = userEle.element("username");
            //获取文本
            System.out.println("username:"+usernameEle.getText());
            Element passwordEle = userEle.element("pwd");
            System.out.println("password:"+passwordEle.getText());
            //属性
            Attribute id = userEle.attribute("userId");
            System.out.println("id属性的值:"+id.getText());
        }
    }
}运行结果:

总结
到此这篇关于Java使用dom4j解析xml、读取xml文件的文章就介绍到这了,更多相关Jav dom4j解析读取xml文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
