`
yang2617
  • 浏览: 28652 次
社区版块
存档分类
最新评论

java解析xml

    博客分类:
  • java
阅读更多
java解析xml文件有四种方式:
1.DOM.
DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准,是以树型结构来表示XML内容.
优点:将整个XML文档一次加载到内存,节点与节点关系也能体现,因此定位节点非常方便,修改文档效率高,且可读可写。
缺点:正是因为一次加载到内存,所以消耗内存,对大文件解析将很吃力。


2.SAX.
采用事件处理机制,一次从头读到尾,不会将整个文件一次加载到内存中,而是读取一部分,解析一部分,占用的内存少。
既然采用事件处理机制,也就回调模式,开发者继承一个SAX解析处理类,然后重写一些方法,当解析XML文档时,发现特定的标签,触发一系列的事件,调用重写方法来处理标签。
优点:处理大型文件效率更高。
确定:只读不写,只能从头读到尾,不能反复操作,实现比较复杂。


3.JDOM.
是Java特定文档模型,把文档的不同内容封装成不同的Java类。
大多数是实现类,极少数是接口,简化了API,限制了灵活性。
大量使用了Java集合框架。


4.DOM4j
大量使用接口,灵活性高,实现更复杂。
大量使用Java中的集合框架。
支持XPath,支持XML Schema,支持XML XSLT。
性能最好。

下面分别用这四中方式解析xml文档.

<?xml version="1.0" encoding="UTF-8"?>
<people>
	<person>
		<name>乔峰</name>
		<famous>降龙十八掌</famous>
	</person>
	<person>
		<name>段誉</name>
		<famous>六脉神剑</famous>
	</person>
	<person>
		<name>虚竹</name>
		<famous>天山折梅手</famous>
	</person>

</people>


1.Dom

package com.xml;

import java.io.File;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.NodeList;

public class XmlDom {
	public static void main(String[] args) {
		try {
			File f = new File("src/com/xml/person.xml");
			DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
			DocumentBuilder db = dbf.newDocumentBuilder();
			Document doc = db.parse(f);
			NodeList nl = doc.getElementsByTagName("person");
			for (int i = 0; i < nl.getLength(); i++) {
				System.out.println("人物:" + doc.getElementsByTagName("name").item(i).getFirstChild().getNodeValue());
				System.out.println("绝技:" + doc.getElementsByTagName("famous").item(i).getFirstChild().getNodeValue());
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}


输出结果为:
人物:乔峰
绝技:降龙十八掌
人物:段誉
绝技:六脉神剑
人物:虚竹
绝技:天山折梅手

2.Sax.

package com.xml;

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

import org.xml.sax.Attributes;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

public class XmlSax extends DefaultHandler {
	@SuppressWarnings("unchecked")
	java.util.Stack tags = new java.util.Stack();

	public XmlSax() {
		super();

	}

	public static void main(String[] args) {
		try {
			SAXParserFactory spf = SAXParserFactory.newInstance();
			SAXParser sp = spf.newSAXParser();
			XmlSax xs = new XmlSax();
			sp.parse(new InputSource("src/com/xml/person.xml"), xs);
		} catch (Exception e) {
			e.printStackTrace();
		}

	}

	@Override
	public void characters(char[] ch, int start, int length) throws SAXException {
		String tag = (String) tags.peek();
		if (tag.equals("name")) {
			System.out.println("人物:" + new String(ch, start, length));
		}
		if (tag.equals("famous")) {
			System.out.println("绝技:" + new String(ch, start, length));
		}
	}

	@SuppressWarnings("unchecked")
	@Override
	public void startElement(String uri, String localName, String qName, Attributes attrs) {
		tags.push(qName);
	}

	@Override
	public void endElement(String uri, String localName, String qName) {

	}

}

输出结果与上面一样.值得注意的是,如果没有startElement方法,则会出现EmptyStackException异常.

3.JDom

package com.xml;

import java.io.File;
import java.util.List;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;

public class XmlJDom {
	@SuppressWarnings("unchecked")
	public static void main(String[] args) {
		try {
			File f = new File("src/com/xml/person.xml");
			SAXBuilder sb = new SAXBuilder();
			Document doc = sb.build(f);
			Element root = doc.getRootElement();
			List ac = root.getChildren();
			for (int i = 0; i < ac.size(); i++) {
				System.out.println("人物:" + ((Element) ac.get(i)).getChild("name").getText());
				System.out.println("绝技:" + ((Element) ac.get(i)).getChild("famous").getText());
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}


JDom需要引入jdom.jar包.同样,dom4j需要引入dom4j.jar包.
4.Dom4j

package com.xml;

import java.io.File;
import java.util.Iterator;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class XmlDom4j {
	@SuppressWarnings("unchecked")
	public static void main(String[] args) {
		try {
			File f = new File("src/com/xml/person.xml");
			SAXReader sr = new SAXReader();
			Document doc = sr.read(f);
			Element root = doc.getRootElement();
			Element el;
			for (Iterator i = root.elementIterator("person"); i.hasNext();) {
				el = (Element) i.next();
				System.out.println("人物:" + el.elementText("name"));
				System.out.println("绝技:" + el.elementText("famous"));
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}
分享到:
评论
1 楼 david01205 2012-07-18  
写得很好,今天下午刚好用到。

相关推荐

    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