首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > XML SOAP >

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

2013-12-29 
Java解析XML文件的两种方式详解Java解析XML文件:常规的两种方式:dom4j方式+jdom方式1.要解析的xml文件?xm

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 小时前   能不能详细说以下这两种解析方式在性能上的优缺点了?数据量也别大的情况下哪种方式解析性能会好点了?谢谢。

热点排行