Dom4J解析XML

1.Dom for java 解析步骤及常用API

1.1 下载依赖的jar包 下载连接 并导入项目

1.2 Dom4J读取解析XML原理分析:

Dom4J解析XML_第1张图片
20180702094927870.png

1.3 Dom4J的常用方法:

  • SAXReader 对象 xml文件读取器
  • Document read(String path);加载执行xml文档
  • Document 对象
  • Element getRootElement() :获取根元素对象(根标签)
  • Element 对象
  • List elements() :获取所有的子元素
  • List elements(String name):根据指定的元素名称来获取相应的所有的子元素
  • Element element(String name):根据指定的元素名称来获取子元素对象,如果元素名称重复,则获取第一个元素
  • String elementText(Stringname) :根据指定的子元素名称,来获取子元素中的文本
  • String getText():获取当前元素对象的文本
  • String attributeValue(Stringname):根据指定的属性名称获取其对应的值

2.Dom4J的解析案例分析:

2.1案例一:

books.xml

    
        斗破苍穹
        86
    
    
        缥缈之旅
        92
    
    
        诛仙
        98
    
    
        鬼吹灯
        124
    
    
        神墓
        128
    

public class Dom4J_01 {
    public static void main(String[] args) throws DocumentException {
        //1.将xml文件加载到内存中
        SAXReader saxReader = new SAXReader();
        //document 加载执行xml文档获取Document对象
        Document document = saxReader.read("books.xml");
        //2.获取根元素的对象 -- books getRootElement 获取根元素
        Element rootElement = document.getRootElement();
        //每个元素的对象 都是Element对象
        List elements = rootElement.elements();
        //3.使用根元素的对象  对其他元素操作操作
        //3.1获取所有的子元素对象 book
        for (Element book : elements) {
            //在循环内拿到了 每个 book  元素对象
            //3.2获取book的属性值
            String author = book.attributeValue("author");
            //3.3获取book的子元素  name price
            String name = book.element("name").getText();
            String price = book.element("price").getText();
            System.out.println(name+" "+author +" "+price );
        }
    }
}
斗破苍穹 天蚕土豆 86
缥缈之旅 萧潜 92
诛仙 萧鼎 98
鬼吹灯 天下霸唱 124
神墓 辰东 128

2.2案例二:

servlet.xml


    
        servlet1
        MyServlet1
    
    
        servlet2
        MyServlet2
    
    
        servlet1
        /s1
    
    
        servlet2
        /s2
    

public class Dom4J_02{
    public static void main(String[] args) throws Exception {
        // 1. 创建一个 saxReader 对象
        SAXReader saxReader = new SAXReader();
        // 2. 将数据读取到 document 对象中
        Document document = saxReader.read("servlet.xml");
        // 3. 使用 document 对象调用 getRootElement 方法获取根标签, 返回 Element 接口实现类对象
        Element rootElement = document.getRootElement();
        // 4. 使用 rootElement 根标签对象调用 elements 方法, 传入 servlet, 获取servlet标签对象
        List servletElements = rootElement.elements("servlet");
        // 5. 遍历, 并获取该标签下的子标签数据内容, 使用父标签对象调用elementText方法, 传入子标签名称获取数据
        for (Element servlet : servletElements) {
            String name = servlet.elementText("servlet-name");
            String cls = servlet.elementText("servlet-class");
            System.out.println(name + " : " + cls);
        }
        // 使用 rootElement 根标签对象调用 elements 方法, 传入 servlet-mapping, 获取servlet-mapping标签对象
        List mappingElements = rootElement.elements("servlet-mapping");
        for (Element mapping : mappingElements) {
            String name = mapping.elementText("servlet-name");
            String url = mapping.elementText("url-pattern");
            System.out.println(name + " = " + url);
        }
    }
}

你可能感兴趣的:(Dom4J解析XML)