xml文件的解析(用dom4j解析)

有个第三方的包,用来解析.xml文件比较方便,它是DOM4J。由于是第三方的,所以要使用它就要先下载,并包含进来。步骤:

1.打开dom4j官网,这里下载最新版dom4j-2.1.1.jar.

2.新建文件夹lib.

3.把下载好的dom4j.jar放到lib文件夹里面。

4.对着dom4j.jar右键-Build Path-Add to Build Path.(1或者2都可以用来解析.xml).

 5.新建类。

 

6.开始写代码:

package com.bjsxt.xml;

import java.io.File;

import javax.swing.text.Document;
import javax.swing.text.html.HTMLDocument.Iterator;
import javax.swing.text.html.parser.Element;

import org.dom4j.Attribute;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
public class TestXml {

    public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        //[1]创建SAXReader对象,用于读取.xml文件
        SAXReader reader = new SAXReader();
        //[2]读取.xml文件,得到document对象,它代表了整个.xml文件。
        org.dom4j.Document doc = reader.read(new File("src/scores.xml"));
        //System.out.println(doc);
        //获取根元素
        org.dom4j.Element root=doc.getRootElement();
        System.out.println("这是根元素:"+root.getName());
        //[4]获取根元素下所有子元素
        java.util.Iterator<org.dom4j.Element> it=root.elementIterator();//获取(获取根元素下)所有子元素的一个迭代器。
        while(it.hasNext())
        {//取出元素
            org.dom4j.Element e=it.next();
            System.out.println(e.getName());
            //获取每个student的id属性:
            Attribute id=e.attribute("id");
            System.out.println(id.getName()+"="+id.getValue());//打印
            org.dom4j.Element name=e.element("name");
            org.dom4j.Element course=e.element("course");
            org.dom4j.Element score=e.element("score");
            System.out.println(name.getName()+"="+name.getStringValue());
            System.out.println(course.getName()+"="+course.getText());
            System.out.println(score.getName() + "=" + score.getText());
            System.out.println("----------------------");
        }
    }

}
/*
 运行结果:
这是根元素:scores
student
id=1
name=王同
course=java
score=89
----------------------
student
id=2
name=李佳
course=sql
score=58
----------------------
student
id=3
name=王二狗
course=经济学原理
score=88
----------------------
student
id=4
name=刘德华
course=怎样做一个好演员
score=100
----------------------

 */

7.上课老师的总结:用dom4j解析.xml的时候,只需注意两点,a.入手点是先创建一个Document对象;b.然后拿Document对象获取根元素,从根元素开始就可以一路用迭代器迭代下去,碰到元素就迭代元素,碰到属性就迭代属性,就可以用属性.getName/getStringValue/getText取出元素的所有属性。

原文地址:https://www.cnblogs.com/yibeimingyue/p/9962700.html