zoukankan      html  css  js  c++  java
  • java解析XML学习总结——SAXReader解析xml文件数据

    第一种方式:

    1. 加入jar包

    注意

        1.1 xml文件解析时编码要一致(默认UTF-8),出现报错可以在记事本中另存为来更改编码格式。

         2.2 jar包两个都需要

    2.gao.xml数据如下:

    <?xml version="1.0" encoding="UTF-8"?>
    <emps>
        <emp>
            <id>1</id>
            <name>张三</name>
            <age>26</age>
            <gender></gender>
            <salary>3000</salary>
        </emp>
        <emp>
            <id>2</id>
            <name>李四</name>
            <age>21</age>
            <gender></gender>
            <salary>2000</salary>
        </emp>
        <emp>
            <id>3</id>
            <name>王五</name>
            <age>28</age>
            <gender></gender>
            <salary>6500</salary>
        </emp>
        <emp>
            <id>4</id>
            <name>赵六</name>
            <age>28</age>
            <gender></gender>
            <salary>5500</salary>
        </emp>
        <emp>
            <id>5</id>
            <name>钱七</name>
            <age>53</age>
            <gender></gender>
            <salary>12000</salary>
        </emp>
        <cmp department="总经办">
            <id>007</id>
            <name>董事长</name>
            <age>52</age>
            <gender></gender>
            <salary>100000</salary>
        </cmp>
    </emps>

    3.XmlDemo.java代码

    package me.gorden.xml;
     
    import java.io.File;
    import java.util.List;
     
    import org.dom4j.Document;
    import org.dom4j.Element;
    import org.dom4j.io.SAXReader;
     
    public class XmlDemo {
        public static void main(String[] args) {
            try {
                // 创建SAXReader
                SAXReader reader = new SAXReader();
                //从xml文件获取数据  
                Document document = reader.read(new File("E:\00_MeWockSpace\MyEclipse 12\xmlDemo\src\gao.xml"));
                // 获取根节点 emps
                Element root = document.getRootElement();
                // 查找指定节点名称QName的所有子节点elements
                List<Element> list = root.elements("emp");  //得到所有emp元素
                System.out.println("list==>"+list);
                
                for (Element element : list) { //循环输出全部emp的相关信息  
                    System.out.println("element.getName()==>"+element.getName());
                    
                    List<Element> list2 = element.elements(); //得到emp元素下的子元素
                    
                    for (Element e : list2) {  //遍历emp元素下的子元素
                        System.out.print(e.getName()+":");  //获取子元素名称
                        System.out.print(e.getText()+" ");  //获取子元素的文本值
                    }
                     System.out.println();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    4.结果

    list==>[org.dom4j.tree.DefaultElement@168afdd [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@1f21056 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@10e8647 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@91cf0b [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@b00ec2 [Element: <emp attributes: []/>]]
    element.getName()==>emp
    id:1 name:张三 age:26 gender:男 salary:3000 
    element.getName()==>emp
    id:2 name:李四 age:21 gender:女 salary:2000 
    element.getName()==>emp
    id:3 name:王五 age:28 gender:女 salary:6500 
    element.getName()==>emp
    id:4 name:赵六 age:28 gender:男 salary:5500 
    element.getName()==>emp
    id:5 name:钱七 age:53 gender:男 salary:12000

    代码解析:
    1、读取xml数据
    SAXReader可以通过多种方式读取xml数据,并返回Document格式的对象。通过查看源码,可以看出read()方法接收File,InputStream和URL等格式的参数来读取相应的xml数据。在代码里我演示了读取xml文档和xml格式的字符串两种方式。当然,字符串要根据相应的编码转成输入流才能被SAXReader读取。
    2、解析xml数据
    读取到Document对象后,我们使用getRootElement()方法获取根元素,返回的是一个Element对象。在本例中,该元素的name即为emps。
    3、获取子元素数据
    获取根元素后,便可以一层一层的去获取他的子元素信息。如果知道子元素的标签名称,便可以直接调用element("name")方法获取该子元素。如果不知道子元素的名称,或者想直接获取该元素下的全部子元素,可以调用elements()方法获取一个包括全部元素的list,然后进行下一步的处理。
    4、输出元素信息
    调用getName()方法获取当前元素的元素名,attributeValue()获取属性名。如果当前元素没有子元素,则调用getText()方法获取元素值。

    第二种方式:

    1.ReadXml.java文件和上面的不一样,其余的都是一样的

    package me.gorden.xml;
     
    import java.io.File;
    import java.util.List;
     
    import org.dom4j.Document;
    import org.dom4j.DocumentException;
    import org.dom4j.Element;
    import org.dom4j.io.SAXReader;
     
    public class ReadXml {
        public static void main(String[] args) throws DocumentException {
            File file = new File("E:\00_MeWockSpace\MyEclipse 12\xmlDemo\src\gao.xml");
            
            System.out.println("file===>"+file);
            // 创建SAXReader
            SAXReader reader = new SAXReader();
            // 用SAXReader来读取文件,并转换成Document
            Document document = reader.read(file);
            //用Document的selectNodes来读取节点,返回list
            List<Object> list = document.selectNodes("/emps/emp/name");
            Element e = null;
            if(list.size()>0){
                e = (Element) list.get(0);
            }
            
            System.out.println("list.size()==>"+list.size());
            
            if(null != e){
                Object obj = e.getData();
                System.out.println("Element内容为:  "+obj);
            }else{
                System.out.println("Element内容为空");
            }
            
        }
    }

    2.结果

    file===>E:0_MeWockSpaceMyEclipse 12xmlDemosrcgao.xml
    list.size()==>5
    Element内容为:  张三

    转: https://blog.csdn.net/qq_36501591/java/article/details/80522531

  • 相关阅读:
    ADO.NET入门教程(五) 细说数据库连接池
    Delphi下使用指针的简单总结
    Delphi
    Delphi
    Delphi
    TXLSReadWriteII5 单元格读写
    [Delphi]Delphi开发的一些技巧
    TXLSReadWriteII2版本导出Excel文件:
    Tomcat使用startup启动,一闪而过,如何查看出错信息
    【转】Java保留固定小数位的4种方法
  • 原文地址:https://www.cnblogs.com/fps2tao/p/13198560.html
Copyright © 2011-2022 走看看