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包(貌似还要个jaxen.jar包。不然会出现【java.lang.NoClassDefFoundError: org/jaxen/JaxenException】).同样,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(); } } }
相关推荐
### Java解析XML技术详解:DOM、SAX、JDOM、DOM4j与XPath #### 一、基础知识概览 在Java开发中,处理XML文件是一项常见的任务。XML(Extensible Markup Language,可扩展标记语言)是一种用于存储和传输数据的标准...
JAVA xml 的四种解析方式,(1)Dom生成和解析XML文档 (2)SAX生成和解析XML文档(3)DOM4J生成和解析XML文档 (4)JDOM生成和解析XML
通过以上内容,我们了解了如何使用Java解析XML,并展示了如何构建XML树图。对于更复杂的需求,例如添加图形界面展示树图,可以结合JavaFX或Swing等图形库,将XML树结构转化为可视化的组件。此外,还有一些开源库,如...
本篇内容涵盖了 Java 集合框架中 `Set`、`List` 和 `Map` 的核心概念及其实现细节,同时还包括了数组的基本用法以及多线程和 XML 解析的基础知识。这些内容对于 Java 开发者来说是非常重要的基础知识,掌握它们可以...
Java解析XML文件的必要性 在实际开发中,我们经常需要解析XML文件来获取数据,例如,从XML文件中读取配置信息、解析XML文件中的数据等。因此,掌握Java语言解析XML文件的技巧非常重要。 Java解析XML文件的步骤 1....
Java XML读写操作是开发过程中常见的一项任务,尤其在处理配置文件、数据交换或存储结构化数据时。这里我们将深入探讨DOM、SAX、JDOM和DOM4J这四种主要的XML处理方式,并通过具体例子来理解它们的工作原理和用法。 ...
本资料汇总旨在提供一个全面的XML学习资源,包括基础理论、实战应用以及常用解析库的介绍。 一、XML基础知识 XML的设计目标是传输和存储数据,而非显示数据。它采用了自描述的结构,通过标签来定义数据类型和结构。...
它可以在解析XML文档时立即开始,不需要等待所有数据处理完毕。SAX通过触发一系列的事件来识别和处理特定的标签。这种方法的主要优点在于内存要求低,且解析速度快,适合处理大型文档。但是SAX解析器的编码工作比较...
1. **Java解析Excel库** 在Java中,有多个库可以用来解析Excel文件,如Apache POI、JExcelAPI、SimpleExcel等。Apache POI是目前最广泛使用的库,支持`.xls`和`.xlsx`格式,功能强大且稳定。我们将主要讨论使用...
首先,创建`DocumentBuilderFactory`实例,然后通过该实例创建`DocumentBuilder`对象,用于解析XML文件并生成`Document`对象。例如: ```java DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();...
Java 操作 XML 的方法汇总及解析 Java 操作 XML 的方法汇总及解析是 Java 语言中的一种常见操作,主要用于解析和处理 XML 文件。XML(Extensible Markup Language)是一种标记语言,用于存储和传输数据。Java 语言...
- `javax.xml.parsers.DocumentBuilderFactory` 和 `org.w3c.dom.Document`:用于解析XML文档。 - `javax.xml.transform.TransformerFactory` 和 `Transformer`:XML转换工具。 9. **JSON处理**: - Jackson (`...
### 知识点一:集合(Sets) #### Set 集合 - **特性**:`Set` 是一种不允许重复元素的数据结构。...这些知识点覆盖了 Java 中集合(Set 和 Map)、数组、多线程以及 XML 解析的基本概念和技术细节。
java漏洞汇总,ackson是一套开源的java序列化与反序列化工具框架,可将java对象序列化为xml和json格式的字符串并提供对应的反序列化过程。由于其解析效率较高,Jackson目前是Spring MVC中内置使用的解析方式
最后,Java的标准库(Java API)提供了大量的类和接口,涵盖了网络、数据库连接、XML解析、日期时间处理等多个方面,熟练掌握这些API的使用能够大大提升开发效率。 总的来说,"Java基础知识汇总"文档应该包含了以上...
Java的`javax.xml`和`org.w3c.dom`包提供了XML解析的基础,包括DOM(文档对象模型)和SAX(简单API for XML)解析器。而`jdom`、`dom4j`或`xml Beans`等第三方库则提供了更友好的API来操作XML。 6. **文件上传下载...
【JAVA 面试题汇总】是一份集合了各种JAVA面试常见问题的资料,涵盖了核心JAVA、面向对象设计与UML、XML、SQL、JDBC、Hibernate、Web技术、EJB、Spring、数据结构与算法、计算机基础知识以及C++等多个方面。...
【个人JAVA笔记汇总】是一个全面概述Java编程技术的资源集合,涵盖了多个子领域,包括文件操作、XML处理、日志记录、框架应用以及移动开发。以下是对这些知识点的详细阐述: 1. **JXL库**: JXL是Java的一个库,用于...
《Java报表开发技术深入解析》是一本专注于Java平台上的报表开发技术的专业书籍。该书针对Java开发者,旨在帮助他们理解和掌握如何在Java应用程序中设计、创建和展示复杂的报表。通过阅读此书,读者将能够了解到Java...