当前位置: 代码迷 >> XML/SOAP >> Java解析XML文件的两种形式详解
  详细解决方案

Java解析XML文件的两种形式详解

热度:2565   发布时间:2013-12-29 13:07:03.0
Java解析XML文件的两种方式详解

Java解析XML文件:
常规的两种方式:dom4j方式+jdom方式
1.要解析的xml文件

<?xml version="1.0" encoding="utf-8"?>
<books>
    <book name="ThinkInJava">
        <language>english</language>
        <price>60.0</price>
    </book>
    <book name="Java编程思想">
        <language>chinese</language>
        <price>75.0</price>
    </book>
</books>

?
2.dom4j方式:需要用dom4j.jar包

public class Dom4jXML {

    public Dom4jXML() {
    }

    public void praseXML(String filePath) {
        SAXReader reader = new SAXReader();// 创建一个能读取xml文档的reader
        Document document;// 构建一个文档对象,用来将xml转换成Document对象
        try {
            document = reader.read(new FileInputStream(new File(filePath)));// 从给定的文件中读取xml并且构建成Document
            Element rootElement = document.getRootElement();// 获得文档对象的根节点
            List<Element> listElement = rootElement.elements();// 获得根节点下面所有的子节点
            for (Element e : listElement) {// 遍历所有的子节点
                Element element = e;// 当前节点,也就是Book节点
                Attribute nameAttribute = element.attribute("name");// 得到当前节点的属性对象
                String nameString = nameAttribute.getValue();// 获得属性对象的值
                System.out.println(element.getName() + ":" + nameString);// 将节点信息输出

                Element languageElement = element.element("language");// 获得当前节点的language子节点
                System.out.println(languageElement.getName() + ":" + languageElement.getTextTrim());// 将language节点信息输出

                Element priceElement = element.element("price");
                System.out.println(priceElement.getName() + ":" + priceElement.getText());

                // 判断有没有出版年份节点,要是有就打印出来,要是没有就创建并且添加到Document对象中(添加节点)
                Element yearElement = element.element("year");
                if (yearElement == null) {
                    yearElement = element.addElement("year");
                    yearElement.setText("2014year");
                } else {
                    System.out.println(yearElement.getName() + ":" + yearElement.getTextTrim());
                }

                // 通货膨胀,导致中国物价上涨,凡是汉语书籍涨价10.00元(修改节点)
                if (languageElement.getTextTrim().equals("chinese")) {
                    String priceStr = priceElement.getTextTrim();
                    double priceNum = Double.parseDouble(priceStr);
                    priceNum += 10.00;
                    priceElement.setText(priceNum + "");
                }

            }
            // 将修改以后的Document对象保存成xml到原来的地方
            XMLWriter write = new XMLWriter(new FileWriter(filePath));
            write.write(document);
            write.close();
        } catch (DocumentException e) {
            e.printStackTrace();
        } catch (IOException e1) {
            e1.printStackTrace();
        }
    }

    public static void main(String[] args) {
        new Dom4jXML().praseXML("你自己的xml路径");
    }
}

?
3.jdom方式:需要用到jdom.jar包

public class JdomXML {
    public JdomXML() {
    }

    public void parseXML(String filePath) {
        SAXBuilder builder = new SAXBuilder(false);// 用来读取xml文件
        Document document;// 构建一个文档对象,用来将xml转换成Document对象
        try {
            document = builder.build(new FileInputStream(new File(filePath)));// 从给定的文件中读取xml并且构建成Document
            Element elementRoot = document.getRootElement();// 获得文档对象的根节点
            List<Element> elementList = elementRoot.getChildren("book");// 获得根节点下面所有的Book节点
            for (Element e : elementList) {// 遍历Book节点
                Element element = e;// 当前的Book节点
                String name = element.getAttributeValue("name");// 获得Book节点的name属性

                Element languageElement = element.getChild("language");// 获得Book节点下的language子节点
                String language = languageElement.getValue();// 获得language节点的值

                Element priceElement = element.getChild("price");
                String price = priceElement.getValue();

                // 打印输出子节点相关信息
                System.out.println(element.getName() + ":" + name);
                System.out.println(languageElement.getName() + ":" + language);
                System.out.println(priceElement.getName() + ":" + price);

                // 判断有没有出版年份节点,要是有就打印出来,要是没有就创建并且添加到Document对象中(添加节点)
                Element yearElement = element.getChild("year");
                if (yearElement == null) {
                    yearElement = new Element("year");
                    yearElement.setText("2014year");
                    element.addContent(yearElement);
                } else {
                    System.out.println(yearElement.getName() + ":" + yearElement.getValue());
                }

                // 判断是不是外文书籍,要是外文书籍,就降价1.50元(修改节点)
                if (language.equals("english")) {
                    double priceNum = Double.parseDouble(price);
                    priceNum -= 1.50;
                    priceElement.setText(priceNum + "");
                }
            }
            // 将修改以后的Document对象保存成xml到原来的地方
            XMLOutputter outputter = new XMLOutputter();
            outputter.output(document, new FileOutputStream(new File(filePath)));
        } catch (JDOMException | IOException e) {
            e.printStackTrace();
        }

    }

    public static void main(String[] args) {
        new JdomXML().parseXML("你自己的xml路径");
    }
}

?
说明:两种方式都是可以的,原理基本相同。语法略有不同,但是还是都很好理解。
可以使用这种方法完成一个自己的Spring的IOC的功能玩玩。

1 楼 kt431128 19 小时前  
能不能详细说以下这两种解析方式在性能上的优缺点了?数据量也别大的情况下哪种方式解析性能会好点了?谢谢。
  相关解决方案