zoukankan      html  css  js  c++  java
  • XML(四)dom4j解析XML

    使用dom4j须要导入jar包

    jar包下载地址:http://pan.baidu.com/s/1o65jWRw

    将dom4j-1.6.1.jar包导入Eclipse


     book2.xml

    <?xml version="1.0" encoding="UTF-8"?

    > <书架> <书> <书名>JAVA</书名> <作者>XXXXXX</作者> <售价>23333</售价> </书> <书> <书名>ANDROID</书名> <作者>XXXXXX</作者> <售价>23333</售价> </书> </书架>


     

    解析book2.xml这个文件。

    方法:
    获取文档的根结点:

    Element root = document.getRootElement();

    获取某个结点的子节点

    Element element = root.element();

    获取某个结点下的全部子节点:
    List elements = root.elements();

    遍历该结点下的全部子节点
    以递归的方式进行

    public class dom4j {
    
    	public static void main(String[] args) throws Exception {
    		// method_1();
    		method_2();
    	}
    
    	private static void method_2() throws Exception {
    		SAXReader reader = new SAXReader();
    		Document document = reader.read("book2.xml");
    		Element root = document.getRootElement();
    		parse(root);
    	}
    
    	private static void parse(Element ele) {
    		// 处理当前元素包括的全部属性
    		parseAttribute(ele);
    		// 获取当前元素包括的全部
    		List el = ele.elements();
    		for (Object e : el) {
    			Element element = (Element) e;
    			// 假设该元素的内容不是仅仅包括字符串
    			if (!element.isTextOnly()) {
    				parse(element);
    			} else {
    				// 处理当前 元素的所有属性
    				parseAttribute(element);
    				// 获取当前元素的内容
    				System.out.println(element.getQName().getName() + "-->"
    						+ element.getText());
    			}
    		}
    	}
    
    	/**
    	 * 处理元素属性
    	 * 
    	 * @param ele
    	 */
    	private static void parseAttribute(Element ele) {
    		List attributes = ele.attributes();
    		for (Object e : attributes) {
    			Attribute attribute = (Attribute) e;
    			System.out.println(ele.getQName().getName() + "元素的"
    					+ attribute.getQName().getName() + "属性为"
    					+ attribute.getValue());
    		}
    	}
    
    	private static void method_1() throws Exception {
    		// 获取解析器
    		SAXReader reader = new SAXReader();
    		// 解析xml获代替表整个文档的dom对象
    		Document document = reader.read("book2.xml");
    		// 获取根结点
    		Element rootElement = document.getRootElement();
    		// 获取书名
    		String bookName = rootElement.element("书").element("书名").getText();
    		System.out.println("bookName--:   " + bookName);
    	}
    
    }
    
    


  • 相关阅读:
    建造者模式
    抽象工厂设计模式
    工厂设计模式
    原型设计模式
    单例设计模式
    UML类图的学习
    kafka的客户端操作, stream API
    kafka的客户端操作,consumer API
    kafka的客户端操作,admin与producer
    Optional常用写法
  • 原文地址:https://www.cnblogs.com/llguanli/p/6845707.html
Copyright © 2011-2022 走看看