首页 > 其他 > 详细

XML文本解析

时间:2020-10-08 18:19:34      阅读:32      评论:0      收藏:0      [点我收藏+]

XML 全称 eXtensible Markup Language(指可扩展标记语言),常作为配置文件的文件格式;
解析方式有: dom 和 sax
dom 一次读取,十分耗内存,但可以进行curd操作
sax 逐行读取,内存消耗少,只能进行读操作

解析使用Dom4j库,首先创建一个Maven工程,导包

<!-- https://mvnrepository.com/artifact/dom4j/dom4j -->
<dependency>
    <groupId>dom4j</groupId>
    <artifactId>dom4j</artifactId>
    <version>1.6.1</version>
</dependency>

解析的demo xml内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<person>
    <p1>
        <name>jason</name>
        <age>26</age>
    </p1>
    <p1>
        <name>tom</name>
        <age>18</age>
    </p1>
</person>

创建Java类,进行解析

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

import java.util.List;

public class TestDom4j {
    public static void main(String[] args) throws Exception {
        SelectName();
    }
    public static void SelectName() throws Exception {
        // 创建解析器
        SAXReader saxReader = new SAXReader();
        // 得到Document
        Document document= saxReader.read("src\\main\\resources\\XmlRead.xml");
        // 得到根节点
        Element root = document.getRootElement();
        //得到所有P1
        List<Element> list= root.elements("p1");
//        Element e1= list.get(0);
//        Element e2= list.get(1);

//        //得到第一个p1
//        Element e1= root.element("p1");
//        Element n1 = e1.element("name");
//        System.out.println(n1.getText());

        // 遍历list
        for (Element element : list) {
            Element name1 = element.element("name");
            String s = name1.getText();
            System.out.println(s);
        }
    }
}

整体看,和Xpath解析HTML很类似.

XML文本解析

原文:https://www.cnblogs.com/jason-Gan/p/13781353.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!