`
小皮球
  • 浏览: 33942 次
  • 性别: Icon_minigender_1
  • 来自: 成都
文章分类
社区版块
存档分类
最新评论

java 解析 XML

阅读更多
本文转自:
http://hi.baidu.com/zhanghaooy/blog/item/5636af098f3ce1c43bc76371.html

在读取XML数据的时候可以采用两种实现,可以灵活应用。

XML文件为:

view plaincopy to clipboardprint?
<?xml version="1.0" encoding="ISO-8859-1"?>
<bookstore>
    <book category="COOKING">
      <title lang="en">Everyday Italian</title>
      <author>Giada De Laurentiis</author>
      <year>2005</year>
      <price>30.00</price>
    </book>
    <book category="CHILDREN">
      <title lang="en">Harry Potter</title>
      <author>J K. Rowling</author>
      <year>2005</year>
      <price>29.99</price>
    </book>
    <book category="WEB">
      <title lang="en">XQuery Kick Start</title>
      <author>James McGovern</author>
      <year>2003</year>
      <price>49.99</price>
    </book>
    <book category="EEWEB">
      <title lang="en">Learning XML</title>
      <author>Erik T. Ray</author>
      <year>2003</year>
      <price>39.95</price>
    </book>
</bookstore>
<?xml version="1.0" encoding="ISO-8859-1"?>
<bookstore>
<book category="COOKING">
   <title lang="en">Everyday Italian</title>
   <author>Giada De Laurentiis</author>
   <year>2005</year>
   <price>30.00</price>
</book>
<book category="CHILDREN">
   <title lang="en">Harry Potter</title>
   <author>J K. Rowling</author>
   <year>2005</year>
   <price>29.99</price>
</book>
<book category="WEB">
   <title lang="en">XQuery Kick Start</title>
   <author>James McGovern</author>
   <year>2003</year>
   <price>49.99</price>
</book>
<book category="EEWEB">
   <title lang="en">Learning XML</title>
   <author>Erik T. Ray</author>
   <year>2003</year>
   <price>39.95</price>
</book>
</bookstore>

实现一:

view plaincopy to clipboardprint?
public static void readXML(String xmlFile){ 
         
        try { 
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 
            DocumentBuilder db = dbf.newDocumentBuilder(); 
            Document doc = db.parse(xmlFile); 
            Element root = doc.getDocumentElement(); 
            NodeList ndBooks = root.getElementsByTagName("book"); 
            NodeList ndTitles = root.getElementsByTagName("title"); 
            NodeList ndAuthors = root.getElementsByTagName("author"); 
            NodeList ndYears = root.getElementsByTagName("year"); 
            NodeList ndPrices = root.getElementsByTagName("price"); 
            if(ndBooks != null){ 
                for(int i=0;i<ndBooks.getLength();i++){ 
                    Node ndBook = ndBooks.item(i); 
                    Node ndTitle = ndTitles.item(i); 
                    Node ndAuthor = ndAuthors.item(i); 
                    Node ndYear = ndYears.item(i); 
                    Node ndPrice = ndPrices.item(i); 
                    System.out.println(ndBook.getAttributes().getNamedItem("category").getNodeValue()); 
                    System.out.println(ndTitle.getAttributes().getNamedItem("lang").getNodeValue()); 
                    System.out.println(ndTitle.getFirstChild().getNodeValue()); 
                    System.out.println(ndAuthor.getFirstChild().getNodeValue()); 
                    System.out.println(ndYear.getFirstChild().getNodeValue()); 
                    System.out.println(ndPrice.getFirstChild().getNodeValue()); 
                    System.out.println("--------------------------------"); 
                } 
            } 
        } catch (ParserConfigurationException e) { 
            e.printStackTrace(); 
        } catch (SAXException e) { 
            e.printStackTrace(); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        }        
    }
public static void readXML(String xmlFile){
 
   try {
    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
    DocumentBuilder db = dbf.newDocumentBuilder();
    Document doc = db.parse(xmlFile);
    Element root = doc.getDocumentElement();
    NodeList ndBooks = root.getElementsByTagName("book");
    NodeList ndTitles = root.getElementsByTagName("title");
    NodeList ndAuthors = root.getElementsByTagName("author");
    NodeList ndYears = root.getElementsByTagName("year");
    NodeList ndPrices = root.getElementsByTagName("price");
    if(ndBooks != null){
     for(int i=0;i<ndBooks.getLength();i++){
      Node ndBook = ndBooks.item(i);
      Node ndTitle = ndTitles.item(i);
      Node ndAuthor = ndAuthors.item(i);
      Node ndYear = ndYears.item(i);
      Node ndPrice = ndPrices.item(i);
      System.out.println(ndBook.getAttributes().getNamedItem("category").getNodeValue());
      System.out.println(ndTitle.getAttributes().getNamedItem("lang").getNodeValue());
      System.out.println(ndTitle.getFirstChild().getNodeValue());
      System.out.println(ndAuthor.getFirstChild().getNodeValue());
      System.out.println(ndYear.getFirstChild().getNodeValue());
      System.out.println(ndPrice.getFirstChild().getNodeValue());
      System.out.println("--------------------------------");
     }
    }
   } catch (ParserConfigurationException e) {
    e.printStackTrace();
   } catch (SAXException e) {
    e.printStackTrace();
   } catch (IOException e) {
    e.printStackTrace();
   } 
}

实现二:

view plaincopy to clipboardprint?
public static void readXML2(String xmlFile){ 
        try { 
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 
            DocumentBuilder db = dbf.newDocumentBuilder(); 
            Document doc = db.parse(xmlFile); 
            Element root = doc.getDocumentElement();//root 指向bookstore节点 
            NodeList nls = root.getChildNodes();//nls指向bookstore的子节点book 
            if(nls!= null){ 
                for(int i=0;i<nls.getLength();i++){ 
                    Node nd = nls.item(i);//输出每个book节点的category属性 
                    if(nd.getNodeType() == Node.ELEMENT_NODE){ 
                        System.out.println("book:category:" + nd.getAttributes().getNamedItem("category").getNodeValue()); 
                    } 
                    //以下遍历book节点的所有子节点 
                    for(Node nde = nd.getFirstChild();nde!=null; nde = nde.getNextSibling()){ 
                        if(nde.getNodeType() == Node.ELEMENT_NODE){ 
                            //输出title节点值 
                            if(nde.getNodeName().equals("title")){ 
                                System.out.println("----title:" + nde.getFirstChild().getNodeValue()); 
                            } 
                            //输出author节点值 
                            if(nde.getNodeName().equals("author")){ 
                                System.out.println("----author:" + nde.getFirstChild().getNodeValue()); 
                            } 
                            //输出year节点值 
                            if(nde.getNodeName().equals("year")){ 
                                System.out.println("----year:" + nde.getFirstChild().getNodeValue()); 
                            } 
                            //输出price节点值 
                            if(nde.getNodeName().equals("price")){ 
                                System.out.println("----price:" + nde.getFirstChild().getNodeValue()); 
                            } 
                             
                             
                        } 
                    } 
                     
                } 
            } 
        } catch (ParserConfigurationException e) { 
            e.printStackTrace(); 
        } catch (SAXException e) { 
            e.printStackTrace(); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        } 
    }
public static void readXML2(String xmlFile){
   try {
    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
    DocumentBuilder db = dbf.newDocumentBuilder();
    Document doc = db.parse(xmlFile);
    Element root = doc.getDocumentElement();//root 指向bookstore节点
    NodeList nls = root.getChildNodes();//nls指向bookstore的子节点book
    if(nls!= null){
     for(int i=0;i<nls.getLength();i++){
      Node nd = nls.item(i);//输出每个book节点的category属性
      if(nd.getNodeType() == Node.ELEMENT_NODE){
       System.out.println("book:category:" + nd.getAttributes().getNamedItem("category").getNodeValue());
      }
      //以下遍历book节点的所有子节点
      for(Node nde = nd.getFirstChild();nde!=null; nde = nde.getNextSibling()){
       if(nde.getNodeType() == Node.ELEMENT_NODE){
        //输出title节点值
        if(nde.getNodeName().equals("title")){
         System.out.println("----title:" + nde.getFirstChild().getNodeValue());
        }
        //输出author节点值
        if(nde.getNodeName().equals("author")){
         System.out.println("----author:" + nde.getFirstChild().getNodeValue());
        }
        //输出year节点值
        if(nde.getNodeName().equals("year")){
         System.out.println("----year:" + nde.getFirstChild().getNodeValue());
        }
        //输出price节点值
        if(nde.getNodeName().equals("price")){
         System.out.println("----price:" + nde.getFirstChild().getNodeValue());
        }
      
      
       }
      }
    
     }
    }
   } catch (ParserConfigurationException e) {
    e.printStackTrace();
   } catch (SAXException e) {
    e.printStackTrace();
   } catch (IOException e) {
    e.printStackTrace();
   }
}

第二种方法更可取些。注意理解

调用方法:

view plaincopy to clipboardprint?
public static void main(String[] args) { 
    String xmlFile = "E:\\workspace_g2\\TT\\src、\\books.xml"; 
    readXML2(xmlFile); 
         
    }
public static void main(String[] args) {
    String xmlFile = "E:\\workspace_g2\\TT\\src、\\books.xml";
    readXML2(xmlFile);
 
}

相关文章参见:

http://www.blogjava.net/lcs/archive/2007/11/21/162088.html

http://achievo-bruce-126-com.iteye.com/blog/221480

http://www.91linux.com/html/article/program/java/20070901/6639.html

http://blog.csdn.net/ydsakyclguozi/archive/2008/04/30/2347575.aspx

http://blog.csdn.net/java2000_net/archive/2008/11/06/3241167.aspx
分享到:
评论

相关推荐

    JAVA 解析XML生成XML文档实例

    JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML

    java解析xml字符串

    ### Java解析XML字符串 在给定的代码示例中,我们看到了如何使用JDOM库来解析一个XML字符串,并对其进行操作。下面我们将详细解析这个过程: 1. **初始化XML源**:首先,将XML字符串转化为`StringReader`对象,这...

    java解析XML文件

    Java解析XML文件是Java开发中常见的一项任务,XML(eXtensible Markup Language)作为一种结构化数据存储格式,被广泛用于数据交换、配置文件和Web服务等场景。本篇文章将详细探讨Java如何利用DOM4J库来解析XML文件...

    使用java解析XML文件,解析完之后将解析结果导入mysql数据库中

    本教程将介绍如何使用Java解析XML文件,并将解析结果导入MySQL数据库。 首先,我们需要引入处理XML的Java库——JAXB(Java Architecture for XML Binding)和DOM(Document Object Model)API。JAXB用于对象与XML...

    JAVA解析XML

    ### JAVA解析XML知识点详解 #### 一、XML与JAVA的关系 **XML (eXtensible Markup Language)** 是一种用于标记电子文件使其具有结构性的标记语言。由于其平台无关性、语言无关性和系统的无关性,XML成为了数据交换...

    详 解Java解析XML

    以下是一个简单的DOM解析XML的例子: ```java import javax.xml.parsers.*; import org.w3c.dom.*; import java.io.*; public class DOMExample { public static void main(String[] args) { try { ...

    JAVA 解析xml

    JAVA 解析xml多种方法 JAVA 解析xml多种方法 JAVA 解析xml多种方法 JAVA 解析xml多种方法 JAVA 解析xml多种方法 JAVA 解析xml多种方法 JAVA 解析xml多种方法

    java 解析xml 多级

    Java作为一种广泛使用的后端编程语言,提供了多种方式来解析XML文档,使得处理多级嵌套的数据变得可能。本文将详细讲解如何在Java中解析XML,特别是针对多级结构的情况。 首先,Java提供了两种主要的API来处理XML:...

    java解析XML的四种方式

    ### Java解析XML的四种方式详解 #### 一、DOM(Document Object Model) DOM是一种平台和语言中立的接口,它将XML文档表示为一个树结构,使得程序可以创建、读取、更新或删除树中的元素。DOM实现了W3C的标准,能够...

    java解析xml并导入数据库(dom4j).doc

    Java 解析 XML 并导入数据库(DOM4J) Java 解析 XML 并导入数据库是指使用 Java 语言将 XML 文件解析并将其内容导入到数据库中。下面是使用 DOM4J 库来实现此功能的相关知识点: 一、XML 文件解析 XML...

    java解析xml的四种经典方法

    Java解析XML的四种经典方法是XML处理中常用的技术,它们分别是DOM、SAX、StAX和JDOM。每种方法都有其独特的特性和适用场景,下面将详细介绍这四种方法。 1. DOM(Document Object Model)解析: DOM是W3C制定的一种...

    Java 解析xml 存入mongodb 返回org.json json包

    本篇将详细介绍如何使用Java解析XML,将数据存入MongoDB,并返回org.json JSON包。 首先,解析XML通常有两种主要方法:DOM(Document Object Model)和SAX(Simple API for XML)。DOM一次性加载整个XML文档到内存...

    java解析xml——dom

    ### Java解析XML——DOM详解 #### 一、DOM解析概念 **Document Object Model (DOM)**是一种平台和语言中立的接口,它允许程序和脚本动态地访问和更新文档的内容、结构和样式。DOM最初是为HTML设计的,但后来也被...

    java解析XML的4种经典方法

    Java解析XML的四种经典方法主要涵盖DOM、SAX、StAX和JDOM这四种方式,每种方法都有其独特的优势和适用场景。 1)DOM(JAXP Crimson 解析器) DOM(Document Object Model)是W3C推荐的一种XML解析标准,它将XML...

    详解Java解析XML的四种方法

    本文将深入探讨Java解析XML的四种主要方法。 1. DOM(Document Object Model)解析: DOM解析器将整个XML文档加载到内存中,创建一个树形结构,允许开发者通过节点遍历和操作XML。例如,Java的`javax.xml.parsers....

    Java解析XML工具类--(java源码)

    * 本类是专门解析XML文件的,主要用于为系统读取自己的配置文件时提供最方便的解析操作 * @author HX * */ public class XmlManager { /** * 得到某节点下某个属性的值 * @param element 要获取属性的...

    java 解析XML性能对比分析Demo

    本文将深入探讨几种不同的XML解析方法,并通过实际的“Java解析XML性能对比分析Demo”来展示它们的性能差异。我们将讨论DOM、SAX、JDOM、DOM4J和JAXB这五种解析器,以及它们各自的特点和适用场景。 1. DOM(文档...

    java解析xml的4种方法和json格式

    本篇文章将详细介绍Java解析XML的四种方法以及JSON格式的相关知识。 一、DOM解析 DOM(Document Object Model)是W3C推荐的一种解析XML的标准方法,它将整个XML文档加载到内存中,形成一个树形结构,便于遍历和操作...

    java解析xml生成json对象

    在Java编程环境中,XML(可...总的来说,Java解析XML生成JSON对象的能力使得数据在不同平台和应用间无缝交换成为可能。通过学习和使用这样的工具类,开发者可以更高效地处理XML数据,并将其集成到基于JSON的系统中。

    java解析xml动态生成树形菜单结构

    总结起来,实现“java解析xml动态生成树形菜单结构”的项目,需要掌握以下核心知识点: 1. Java的DOM解析XML,构建树形数据结构。 2. 设计和实现无限层级的树形菜单数据模型。 3. 使用`JSTree`库在前端渲染树形菜单...

Global site tag (gtag.js) - Google Analytics