`
263229365
  • 浏览: 465317 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

jdom操作xml,解析和写入

 
阅读更多

1、解析xml

 

import java.util.Iterator;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;

/**
 *
 * @author Administrator
 */
public class ParseXML {
     public static void main(String args[]){
         
        try {
            SAXBuilder sax = new SAXBuilder(false);
                
            Document document = sax.build("http://localhost:8081/update.xml");
            Element rootEle  = document.getRootElement();
            List fileList = rootEle.getChildren("file");
            for (Iterator i = fileList.iterator(); i.hasNext();) {
                Element employee = (Element) i.next();
                
                List nameList = employee.getChildren("file-name");
                Element nameEle = (Element)nameList.iterator().next();
                String name = nameEle.getText();
                
                List encodeList = employee.getChildren("file-encode");
                Element encodeEle = (Element)encodeList.iterator().next();
                String encode = encodeEle.getText();
                
                System.out.println("nameList=" + name + ",encodeList=" + encode);
            }
        } catch (JDOMException ex) {
            ex.printStackTrace();
        }
    
        
    }
}

 

 

2、写入xml

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;

import org.jdom.input.SAXBuilder;
import org.jdom.output.XMLOutputter;

/**
 *
 * 
 * @author admin
 */
public class MD5Coding {
    
    public MD5Coding(String proFilePath, String xmlName){
        
        createXml(proFilePath, xmlName);
    }
    
    //得到一个指定文件夹的下的所有文件
    public List computeMd5(String path){
        List proFilelist = new ArrayList();        
        try {            
            File file = new File(path);  
            String[] filelist = file.list();            
            for (int i = 0; i < filelist.length; i++) {                
                proFilelist.add(path + "\\" + filelist[i]); 
            }            
        } catch (Exception e) {            
            e.printStackTrace();            
        }        
        return proFilelist;
    }
    
     //生成xml文件,可根据需要进行操作
    public void createXml(String proFilePath, String xmlName) {
        
        try {
            Element rootEle = new Element("update-files");  
            List proFilelist = computeMd5(proFilePath);
            for(int i=0;i<proFilelist.size();i++){
                String proFilename = proFilelist.get(i).toString();
                File proFile = new File(proFilename);

                String proEncode = Md5.encode(proFile);
                String proName = proFile.getName();

                if(proName.endsWith("zip") || proName.endsWith("jar")){
                    Element fileEle = new Element("file");  
                    Element nameEle = new Element("file-name");  
                    nameEle.addContent(proName);  
                    Element encodeEle = new Element("file-encode");  
                    encodeEle.addContent(proEncode);  
                    fileEle.addContent(nameEle);  
                    fileEle.addContent(encodeEle);  
                    rootEle.addContent(fileEle);
                }
            }
            
            Document doc = new Document(rootEle);  

            String xmlFileName = proFilePath + "\\" + xmlName;
            XMLOutputter out = new XMLOutputter("    ",  true, "UTF-8");  
            out.output(doc, new FileOutputStream(xmlFileName));  
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    public static void main(String args[]){
        String proFilePath = "D:\\work\\临时存放文件";
        String xmlName = "update.xml";
        new MD5Coding(proFilePath, xmlName);
    }
} 

  

以上是个人项目中的部分代码,下面附上两篇别处找来的!

 

1-------

 

xml是一种广为使用的可扩展标记语言,java中解析xml的方式有很多,最常用的像jdom、dom4j、sax等等。前两天刚好有个程序需要解析xml,就学了下jdom,写了个小例子,这里做个学习笔记。

 

    要使用jdom解析xml文件,需要下载jdom的包,我使用的是jdom-1.1。解压之后,将lib文件夹下的.jar文件以及build文件夹下的jdom.jar拷贝到工程文件夹下,然后就可以使用jdom操作xml文件了。

 

    一、读取xml文件

 

    假设有这样一个xml文件:

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <sys-config>  
  3.     <jdbc-info>  
  4.         <driver-class-name>oracle.jdbc.driver.OracleDriver</driver-class-name>  
  5.         <url>jdbc:oracle:thin:@localhost:1521:database</url>  
  6.         <user-name>why</user-name>  
  7.         <password>why</password>  
  8.     </jdbc-info>  
  9.     <provinces-info>  
  10.         <province id="hlj" name="黑龙江">  
  11.             <city id="harb">哈尔滨</city>  
  12.             <city id="nj">嫩江</city>  
  13.         </province>  
  14.         <province id="jl" name="吉林"></province>  
  15.     </provinces-info>  
  16. </sys-config>  

 

    首先,用 org.jdom.input.SAXBuilder 这个类取得要操作的xml文件,会返回一个 org.jdom.Document 对象,这里需要做一下异常处理。然后,取得这个xml文件的根节点,org.jdom.Element 代表xml文件中的一个节点,取得跟节点后,便可以读取xml文件中的信息。利用 org.jdom.xpath.XPath 可以取得xml中的任意制定的节点中的信息。

    例如,要取得上面文件中的 <jdbc-info> 下的 <driver-class-name> 中的内容,先取得这个节点Element driverClassNameElement = (Element)XPath.selectSingleNode(rootEle, "//sys-config/jdbc-info/driver-class-name"),注意,根节点前要使用两个 "/" ,然后,用 driverClassNameElement.getText() 便可以取得这个节点下的信息。

    如果一个节点下有多个名称相同的子节点,可以用XPath.selectNodes()方法取得多个子节点的List,遍历这个List就可以操作各个子节点的内容了。

    下面是我写的读取上面xml文件的例子,比起文字描述更直观一些吧:

Java代码   收藏代码
  1. package com.why.jdom;  
  2.   
  3. import java.io.IOException;  
  4. import java.util.Iterator;  
  5. import java.util.List;  
  6.   
  7. import org.jdom.input.SAXBuilder;  
  8. import org.jdom.xpath.XPath;  
  9. import org.jdom.Document;  
  10. import org.jdom.Element;  
  11. import org.jdom.JDOMException;  
  12.   
  13. public class ReadXML {  
  14.   
  15.     /** 
  16.      * @param args 
  17.      */  
  18.     public static void main(String[] args) {  
  19.         SAXBuilder sax = new SAXBuilder();  
  20.         try {  
  21.             Document doc = sax.build("src/config.xml");  
  22.             Element rootEle = doc.getRootElement();  
  23.             Element driverClassNameElement = (Element)XPath.selectSingleNode(rootEle, "//sys-config/jdbc-info/driver-class-name");  
  24.             String driverClassName = driverClassNameElement.getText();  
  25.             System.out.println("driverClassName = " + driverClassName);  
  26.               
  27.             List provinceList = XPath.selectNodes(rootEle, "//sys-config/provinces-info/province");  
  28.             for(Iterator it = provinceList.iterator();it.hasNext();){  
  29.                 Element provinceEle = (Element)it.next();  
  30.                 String proId = provinceEle.getAttributeValue("id");  
  31.                 String proName = provinceEle.getAttributeValue("name");  
  32.   
  33.                 System.out.println("provinceId = " + proId + "   provinceName = " + proName);  
  34.                   
  35.                 List cityEleList = (List)provinceEle.getChildren("city");  
  36.                   
  37.                 for(Iterator cityIt = cityEleList.iterator();cityIt.hasNext();){  
  38.                     Element cityEle = (Element)cityIt.next();  
  39.                     String cityId = cityEle.getAttributeValue("id");  
  40.                     String cityName = cityEle.getText();  
  41.   
  42.                     System.out.println("    cityId = " + cityId + "   cityName = " + cityName);  
  43.                 }  
  44.             }  
  45.         } catch (JDOMException e) {  
  46.             // TODO 自动生成 catch 块  
  47.             e.printStackTrace();  
  48.         } catch (IOException e) {  
  49.             // TODO 自动生成 catch 块  
  50.             e.printStackTrace();  
  51.         }  
  52.   
  53.     }  
  54.   
  55. }  

 

 

    二、写xml文件

 

    写xml文件与读取xml文件的操作类似,利用 org.jdom.output.XMLOutputter 就可以将处理好的xml输出到文件了。可以设置文件的编码方式,不过一般使用UTF-8就可以了。代码如下:

 

Java代码   收藏代码
  1. package com.why.jdom;  
  2.   
  3. import java.io.FileNotFoundException;  
  4. import java.io.FileOutputStream;  
  5. import java.io.IOException;  
  6.   
  7. import org.jdom.Document;  
  8. import org.jdom.Element;  
  9. import org.jdom.output.XMLOutputter;  
  10.   
  11. public class WriteXML {  
  12.   
  13.           
  14.     /** 
  15.      * @param args 
  16.      */  
  17.     public static void main(String[] args) {  
  18.         // TODO 自动生成方法存根  
  19.         Element rootEle = new Element("sys-config");  
  20.         Element provincesEle = new Element("provinces-info");  
  21.           
  22.         Element provinceEle = new Element("province");  
  23.         provinceEle.setAttribute("id","hlj");  
  24.         provinceEle.setAttribute("name","黑龙江省");  
  25.           
  26.         Element cityEle1 = new Element("city");  
  27.         cityEle1.setAttribute("id","harb");  
  28.         cityEle1.addContent("哈尔滨");  
  29.           
  30.         Element cityEle2 = new Element("city");  
  31.         cityEle2.setAttribute("id","nj");  
  32.         cityEle2.addContent("嫩江");  
  33.           
  34.           
  35.         provinceEle.addContent(cityEle1);  
  36.         provinceEle.addContent(cityEle2);  
  37.         provincesEle.addContent(provinceEle);  
  38.         rootEle.addContent(provincesEle);  
  39.           
  40.         Document doc = new Document(rootEle);  
  41.           
  42.         XMLOutputter out = new XMLOutputter();  
  43.           
  44.           
  45. //      out.setFormat(Format.getCompactFormat().setEncoding("GBK"));//设置文件编码,默认为UTF-8  
  46.         String xmlStr = out.outputString(doc);  
  47.         System.out.println(xmlStr);  
  48.           
  49.         try {  
  50.             out.output(doc, new FileOutputStream("c:/test.xml"));  
  51.         } catch (FileNotFoundException e) {  
  52.             // TODO 自动生成 catch 块  
  53.             e.printStackTrace();  
  54.         } catch (IOException e) {  
  55.             // TODO 自动生成 catch 块  
  56.             e.printStackTrace();  
  57.         }  
  58.           
  59.     }  
  60.   
  61. }  

 

2------

 

使用JDOM解析XML
一、前言
    JDOM是Breet Mclaughlin和Jason Hunter两大Java高手的创作成果,2000年初,JDOM作为一个开放源代码项目正式开始研发。JDOM是一种解析XML的Java工具包。 
    DOM适合于当今流行的各种语言,包括Java,JavaScripte,VB,VBScript,Perl,C,C++等。它了为HTML和XML文档提供了一个可应用于不同平台的编程接口。W3C DOM的最新信息可从
http://www.w3.org/TR2001/WD-DOM-Lever-3-Core-20010913查阅。微软在http://msdn.microsoft.com/library/default.asp?url=/library/en-us/xmlsdk30/htm/xmconxmldomuserguide.asp上也有DOM的详细技术信息。

   DOM的设计为了适用于不同的语言,它保留了不同语言中非常相似的API。但是它并不适合于Java编程者的习惯。而JDOM作为一种轻量级API被制定,它最核心的要求是以Java为中心,只适合于Java语言,它遵循DOM的接口主要规则,除去了DOM中为了兼容各语言而与Java习惯的不同。

二、使用JDOM的前提条件
   须要有SAX、DOM解析器的类文件,JDOM只是一种适合Java程序员来使用的Java XML解析器,目前流行的Java XML解析器还有:Apache Xerces Java、JAXP。
Xerces Java解析器是完全用Java编写的XML解析器,最新版本是2.5,它支持以下标准和API:

(1) XML1.0规范(第二版本)

(2) XML命名空间规范

(3) DOM2核心标准规范

(4) SAX2核心扩展

(5) JAXP1.2 :是Sun提供的使用Java处理XML的接口API。

(6) XML Schema结构和数据类型标准  

      还有最好的是它开放源代码,我们可以在
http://xml.apache.org/dist/xerces-j/ 处去下载。下载文件Xerces-J-bin.2.5.0.zip。
解压下载文件,得到四个压缩包加到项目的路径中(其实不要全加,但不熟的情况下考虑这么做)。
JDOM的二进制版本下载:
http://www.jdom.org/downloads/index.html
把解压后的jdom.jar文件加到项目的类路径中,另外便于调试,还要下载它的源代码。

三、使用JDOM解析XML
     好了,现在该是正题了。下面通过一个简单的例子说明一下怎么用JDOM这一适合Java程序员习惯的工具包来解析XML文档。
为了简单,我用了如下XML作为要解析的XML文件:

<?xml version="1.0" encoding="utf-8"?>
<books>
   <book email="zhoujunhui">
     <name>rjzjh</name>
     <price>60.0</price>
  </book>
</books>
够简单的吧,但它对于我们关心的东西都有了,子节点,属性。
下面是用于解析这个XML文件的Java文件:


1 public class JDomParse {
2    public JDomParse(){
3        String xmlpath="library.xml";
4        SAXBuilder builder=new SAXBuilder(false);
5        try {
6            Document doc=builder.build(xmlpath);
7            Element books=doc.getRootElement();
8            List booklist=books.getChildren("book");
9            for (Iterator iter = booklist.iterator(); iter.hasNext();) {
10                Element book = (Element) iter.next();
11                String email=book.getAttributeValue("email");
12                System.out.println(email);
13                String name=book.getChildTextTrim("name");
14                System.out.println(name);
15                book.getChild("name").setText("alterrjzjh");
16                
17            }
18            
19            XMLOutputter outputter=new XMLOutputter();
20            outputter.output(doc,new FileOutputStream(xmlpath));
21            
22        } catch (JDOMException e) {
23            e.printStackTrace();
24        } catch (IOException e) {
25            e.printStackTrace();
26        }
27    }
28    public static void main(String[] args) {
29        new JDomParse();
30    }
31}
不到30行代码,现在我对代码解释一下:
四、解释代码
引用的类:
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
//下面是引用到JDOM中的类
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.output.XMLOutputter;
(1)使用JDOM首先要指定使用什么解析器。如:
        SAXBuilder builder=new SAXBuilder(false); 这表示使用的是默认的解析器
(2)得到Document,我们以后要进行的所有操作都是对这个Document操作的:
        Document doc=builder.build(xmlpath);
(3)得到根元素:
        Element books=doc.getRootElement();
在JDOM中所有的节点(DOM中的概念)都是一个org.jdom.Element类,当然他的子节点也是一个org.jdom.Element类。
(4)得到元素(节点)的集合:
      List booklist=books.getChildren("book");
这表示得到“books”元素的所在名称为“book”的元素,并把这些元素都放到一个List集合中
(5)轮循List集合
     for (Iterator iter = booklist.iterator(); iter.hasNext();) {
       Element book = (Element) iter.next();
    }
还有一种轮循方法是:
    for(int i=0;I       Element book=(Element)booklist.get(i);
    }
(6)取得元素的属性:
    String email=book.getAttributeValue("email");
   取得元素book的属性名为“email”的属性值。
(7)取得元素的子元素(为最低层元素)的值:
    String name=book.getChildTextTrim("name");
    注意的是,必须确定book元素的名为“name”的子元素只有一个。
(8)改变元素(为最低层元素)的值:
    book.getChild("name").setText("alterrjzjh");
    这只是对Document的修改,并没有在实际的XML文档中进行修改
(9)保存Document的修改到XML文件中:
   XMLOutputter outputter=new XMLOutputter();
    outputter.output(doc,new FileOutputStream(xmlpath));

我们先要有一个XMLOutputter类,再把已经修改了的Document保存进XML文档中。

<!--EndFragment-->

 

<!--EndFragment-->

 

0
2
分享到:
评论

相关推荐

    jdom1.1.3xml解析工具类

    org.jdom.adapters包含了与dom适配的java类 org.jdom.filter包含了xml文档的过滤器类 org.jdom.input包含了读取xml文档的类 org.jdom.output包含了写入xml文档的类 org.jdom.transform包含了将jdomxml 文档接口转换...

    自己总结的操作xml文件的方法

    用jdom 操作xml文档 jdom+xpath 操作 xml 文档 Xstream

    JDOM(java)使用详解及实例

    JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析、生成、序列化以及多种操作。 JDOM 直接为JAVA编程服务。它利用更为强有力的JAVA语言的诸多特性(方法重载、集合概念以及映射),把SAX和...

    xml入门教程/xml入门教程

    2.xml文件是由元素和元素的内容以及属性组成的,一个xml文件中只能有一个根元素,标签和标签的内容加在一起叫作一个元素。xml是大小写 敏感的,只能以字母或下划线开头。 字符转义 &lt; 代表 ", &gt; 代表 "&gt;" , &...

    通用的POI导入Excel解决方案

    在项目中,经常免不了要导入、导出Excel,导出Excel稍微简单点,制作一张模板,然后将查询之后的数据写入到模板中即可,导出程序可以做到一次写好,基本上就可以通用...Jdom :解析XML描述文件 POI3.0 : 读取Excel文件

    ZipParserToXml:为公司做的小工具,解析zip文件,读取zip文件中的所有的文件名字,生成到一个xml文件

    ZipParserToXml ZipParserToXML这是eclipse创建的Java项目,完成了将zip文件解析为XML文件的特定路径的功能。 要点如下: 1如何解析zip文件,这是google提供的一种文件... 3创建XML文件,并通过JDOM jar将数据写入XML。

    java源码包---java 源码 大量 实例

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    JAVA上百实例源码以及开源项目

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    java源码包2

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    JAVA上百实例源码以及开源项目源代码

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    java源码包3

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    java源码包4

     Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流。 Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰...

    成百上千个Java 源码DEMO 4(1-4是独立压缩包)

    Java访问权限控制源代码 1个目标文件 摘要:Java源码,文件操作,权限控制 Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流...

    成百上千个Java 源码DEMO 3(1-4是独立压缩包)

    Java访问权限控制源代码 1个目标文件 摘要:Java源码,文件操作,权限控制 Java访问权限控制,为Java操作文件、写入文件分配合适的权限,定义写到文件的信息、定义文件,输出到c:/hello.txt、写信息到文件、关闭输出流...

    千方百计笔试题大全

    202、用jdom解析xml文件时如何解决中文问题?如何解析? 48 203、编程用JAVA解析XML的方式. 49 204、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的区别? 51 205、EJB与JAVA BEAN的区别? 51 206、EJB的基本...

    java面试宝典

    202、用jdom解析xml文件时如何解决中文问题?如何解析? 48 203、编程用JAVA解析XML的方式. 49 204、EJB2.0有哪些内容?分别用在什么场合? EJB2.0和EJB1.1的区别? 51 205、EJB与JAVA BEAN的区别? 51 206、EJB的基本...

Global site tag (gtag.js) - Google Analytics