- 浏览: 65809 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (52)
- tcp ip udp http socket之间关系 (1)
- JDK中使用到的23个经典设计模式 (1)
- linux (1)
- 堆和栈 (1)
- java基本数据类型的转化 (1)
- 垃圾回收机制 (1)
- 提高oracle的sql效率 (1)
- java有内存溢出 (1)
- java Exception的区别 (1)
- Reader和InputStream的区别 (1)
- hashMap和hashtable的区别深入解析 (1)
- Java语言常用性能优化技巧 (1)
- 面试部分问题 (1)
- 数据库索引实现原理 (1)
- open (1)
- showModalDialog (1)
- showModelessDialog 区别 (1)
- javascript 关于类得5种写法 (1)
- html知识点 (1)
- iframe 和 frame的区别 (1)
- js继承 (1)
- tomcat热部署的实现原理 (1)
- tomcat 运行原理 (1)
- html5视频播放 (1)
- HTML5的新功能 (1)
- CSS的继承性 (1)
- Oracle (1)
- Java对象池技术的原理及其实现 (1)
- Java中关于单例模式的10个面试问题 (1)
- Android执行shell命令 (1)
- 什么是高内聚、低耦合? (0)
最新评论
-
respondnet:
非常感谢.
Android执行shell命令(转) -
五陵豪杰:
初学,thanks
tomcat 运行原理 -
贰哲子:
session.flush()具体作用是什么?[size=xx ...
hibernate的批量处理
在java环境下读取xml文件的方法主要有4种:DOM、SAX、JDOM、JAXB
1. DOM(Document Object Model)
此 方法主要由W3C提供,它将xml文件全部读入内存中,然后将各个元素组成一棵数据树,以便快速的访问各个节点 。 因此非常消耗系统性能 ,对比较大的文档不适宜采用DOM方法来解析。 DOM API 直接沿袭了 XML 规范。每个结点都可以扩展的基于 Node 的接口,就多态性的观点来讲,它是优秀的,但是在 Java 语言中的应用不方便,并且可读性不强。
实例:
- import javax.xml.parsers.*;
- //XML解析器接口
- import org.w3c.dom.*;
- //XML的DOM实现
- import org.apache.crimson.tree.XmlDocument;
- //写XML文件要用到
- DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
- //允许名字空间
- factory.setNamespaceAware(true);
- //允许验证
- factory.setValidating(true);
- //获得DocumentBuilder的一个实例
- try {
- DocumentBuilder builder = factory.newDocumentBuilder();
- } catch (ParserConfigurationException pce) {
- System.err.println(pce);
- // 出异常时输出异常信息,然后退出,下同
- System.exit(1);
- }
- //解析文档,并获得一个Document实例。
- try {
- Document doc = builder.parse(fileURI);
- } catch (DOMException dom) {
- System.err.println(dom.getMessage());
- System.exit(1);
- } catch (IOException ioe) {
- System.err.println(ioe);
- System.exit(1);
- }
- //获得根节点StuInfo
- Element elmtStuInfo = doc.getDocumentElement();
- //得到所有student节点
- NodeList nlStudent = elmtStuInfo.getElementsByTagNameNS(
- strNamespace, "student");
- for (……){
- //当前student节点元素
- Element elmtStudent = (Element)nlStudent.item(i);
- NodeList nlCurrent = elmtStudent.getElementsByTagNameNS(
- strNamespace, "name");
- }
import javax.xml.parsers.*; //XML解析器接口 import org.w3c.dom.*; //XML的DOM实现 import org.apache.crimson.tree.XmlDocument; //写XML文件要用到 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); //允许名字空间 factory.setNamespaceAware(true); //允许验证 factory.setValidating(true); //获得DocumentBuilder的一个实例 try { DocumentBuilder builder = factory.newDocumentBuilder(); } catch (ParserConfigurationException pce) { System.err.println(pce); // 出异常时输出异常信息,然后退出,下同 System.exit(1); } //解析文档,并获得一个Document实例。 try { Document doc = builder.parse(fileURI); } catch (DOMException dom) { System.err.println(dom.getMessage()); System.exit(1); } catch (IOException ioe) { System.err.println(ioe); System.exit(1); } //获得根节点StuInfo Element elmtStuInfo = doc.getDocumentElement(); //得到所有student节点 NodeList nlStudent = elmtStuInfo.getElementsByTagNameNS( strNamespace, "student"); for (……){ //当前student节点元素 Element elmtStudent = (Element)nlStudent.item(i); NodeList nlCurrent = elmtStudent.getElementsByTagNameNS( strNamespace, "name"); }
对于读取得方法其实是很简单的,写入xml文件也是一样不复杂。
- DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
- DocumentBuilder builder = null;
- try {
- builder = factory .newDocumentBuilder();
- } catch (ParserConfigurationException pce) {
- System.err.println(pce);
- System.exit(1);
- }
- Document doc = null;
- doc = builder .newDocument();
- //下面是建立XML文档内容的过程,
- //先建立根元素"学生花名册"
- Element root = doc.createElement("学生花名册");
- //根元素添加上文档
- doc.appendChild(root);
- //建立"学生"元素,添加到根元素
- Element student = doc.createElement("学生");
- student.setAttribute("性别", studentBean.getSex());
- root.appendChild(student);
- //建立"姓名"元素,添加到学生下面,下同
- Element name = doc.createElement("姓名");
- student.appendChild(name);
- Text tName = doc.createTextNode(studentBean.getName());
- name.appendChild(tName);
- Element age = doc.createElement("年龄");
- student.appendChild(age);
- Text tAge = doc.createTextNode(String.valueOf(studentBean.getAge()));
- age.appendChild(tAge);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = null; try { builder = factory .newDocumentBuilder(); } catch (ParserConfigurationException pce) { System.err.println(pce); System.exit(1); } Document doc = null; doc = builder .newDocument(); //下面是建立XML文档内容的过程, //先建立根元素"学生花名册" Element root = doc.createElement("学生花名册"); //根元素添加上文档 doc.appendChild(root); //建立"学生"元素,添加到根元素 Element student = doc.createElement("学生"); student.setAttribute("性别", studentBean.getSex()); root.appendChild(student); //建立"姓名"元素,添加到学生下面,下同 Element name = doc.createElement("姓名"); student.appendChild(name); Text tName = doc.createTextNode(studentBean.getName()); name.appendChild(tName); Element age = doc.createElement("年龄"); student.appendChild(age); Text tAge = doc.createTextNode(String.valueOf(studentBean.getAge())); age.appendChild(tAge);
2.SAX (Simple API for XML)
此方法主要由XML-DEV 邮件列表的成员开发的,SAX是基于事件的方法,它很类似于标签库的处理机制,在标签开始、结束以及错误发生等等地方调用相应的接口实现方法,不是全部文 档都读入内存。 SAX具有优异的性能和利用更少的存储空间特点。SAX 的设计只考虑了功能的强大性,却没有考虑程序员使用起来是否方便。
使用必须扩展ContentHandler、ErrorHandler、DTDHandler等,但是必须扩展ContentHandler(或者DefaultHandler )。
- import org.xml.sax.*;
- public class MyContentHandler implements ContentHandler {
- … …
- }
- /**
- * 当其他某一个调用事件发生时,先调用此方法来在文档中定位。
- * @param locator
- */
- public void setDocumentLocator(Locator locator){
- }
- /**
- * 在解析整个文档开始时调用
- * @throws SAXException
- */
- public void startDocument() throws SAXException{
- System.out.println("** Student information start **");
- }
- /**
- * 在解析整个文档结束时调用
- * @throws SAXException
- */
- public void endDocument() throws SAXException{
- System.out.println("**** Student information end ****");
- }
- /**
- * 在解析名字空间开始时调用
- * @param prefix
- * @param uri
- * @throws SAXException
- */
- public void startPrefixMapping(String prefix
- , String uri) throws SAXException{
- }
- /**
- * 在解析名字空间结束时调用
- * @param prefix
- * @throws SAXException
- */
- public void endPrefixMapping(String prefix) throws SAXException{
- }
- /**
- * 在解析元素开始时调用
- * @param namespaceURI
- * @param localName
- * @param qName
- * @param atts
- * @throws SAXException
- */
- public void startElement(String namespaceURI, String localName
- , String qName, Attributes atts) throws SAXException{
- }
- /** 在解析元素结束时调用
- * @param namespaceURI
- * @param localName 本地名,如student
- * @param qName 原始名,如LIT:student
- * @throws SAXException */
- public void endElement(String namespaceURI, String localName,String qName) throws SAXException{
- if (localName.equals(“student”)){
- System.out.println(localName+":"+currentData);
- }
- }
import org.xml.sax.*; public class MyContentHandler implements ContentHandler { … … } /** * 当其他某一个调用事件发生时,先调用此方法来在文档中定位。 * @param locator */ public void setDocumentLocator(Locator locator){ } /** * 在解析整个文档开始时调用 * @throws SAXException */ public void startDocument() throws SAXException{ System.out.println("** Student information start **"); } /** * 在解析整个文档结束时调用 * @throws SAXException */ public void endDocument() throws SAXException{ System.out.println("**** Student information end ****"); } /** * 在解析名字空间开始时调用 * @param prefix * @param uri * @throws SAXException */ public void startPrefixMapping(String prefix , String uri) throws SAXException{ } /** * 在解析名字空间结束时调用 * @param prefix * @throws SAXException */ public void endPrefixMapping(String prefix) throws SAXException{ } /** * 在解析元素开始时调用 * @param namespaceURI * @param localName * @param qName * @param atts * @throws SAXException */ public void startElement(String namespaceURI, String localName , String qName, Attributes atts) throws SAXException{ } /** 在解析元素结束时调用 * @param namespaceURI * @param localName 本地名,如student * @param qName 原始名,如LIT:student * @throws SAXException */ public void endElement(String namespaceURI, String localName,String qName) throws SAXException{ if (localName.equals(“student”)){ System.out.println(localName+":"+currentData); } }
取得元素数据的方法——characters
取得元素数据中的空白的方法——ignorableWhitespace
在解析到处理指令时调用的方法——processingInstruction
当未验证解析器忽略实体时调用的方法——skippedEntity
运行时,只需要使用下列代码:
MySAXParser mySAXParser = new MySAXParser(); mySAXParser.parserXMLFile("SutInfo.xml");
3.JDOM
JDOM的处理方式有些类似于DOM,但它主要是用SAX实现的 。JDOM用Java的数据类型来定义操作数据树的各个节点 。JDOM的性能也很优越。
- import org.jdom.*;
- import org.jdom.input.*;
- import org.jdom.output.*;
- SAXBuilder builder = new SAXBuilder(false);
- //得到Document
- Document doc = builder.build(fileURI);
- //名字空间
- Namespace ns = Namespace.getNamespace("LIT" , "http://www.lit.edu.cn/student/ ");
- //取得所有LIT:student节点的集合
- List lstStudents = elmtStuInfo.getChildren("student",ns);
- for ( … ){
- Element elmtStudent = (Element)lstStudents.get(i);
- elmtStudent.getChildTextTrim("name", ns);
- }
- //修改
- elmtLesson.getChild("lessonScore" , ns).setText("100");
- //删除
- elmtStuInfo.removeChild("master", ns);
- //添加
- elmtStuInfo.addContent(new Element("master" , ns).addContent(new Entity("masterName")));
- //输出文档
- //第一个参数是缩进字符串,这里是4个空格。
- //第二个参数是true,表示需要换行。
- XMLOutputter printDoc = new XMLOutputter(" ", true);
- printDoc.output(doc, new FileOutputStream("StuInfo.xml"));
import org.jdom.*; import org.jdom.input.*; import org.jdom.output.*; SAXBuilder builder = new SAXBuilder(false); //得到Document Document doc = builder.build(fileURI); //名字空间 Namespace ns = Namespace.getNamespace("LIT" , "http://www.lit.edu.cn/student/ "); //取得所有LIT:student节点的集合 List lstStudents = elmtStuInfo.getChildren("student",ns); for ( … ){ Element elmtStudent = (Element)lstStudents.get(i); elmtStudent.getChildTextTrim("name", ns); } //修改 elmtLesson.getChild("lessonScore" , ns).setText("100"); //删除 elmtStuInfo.removeChild("master", ns); //添加 elmtStuInfo.addContent(new Element("master" , ns).addContent(new Entity("masterName"))); //输出文档 //第一个参数是缩进字符串,这里是4个空格。 //第二个参数是true,表示需要换行。 XMLOutputter printDoc = new XMLOutputter(" ", true); printDoc.output(doc, new FileOutputStream("StuInfo.xml"));
4.JAXB (Java And XML Binding)
JAXB 是以SUN为主的一些公司公布的。JAXB将schema(或者DTD)映射为java对象(.java文件),然后使用这些java对象来解析xml文件。需要使用之前生成java文件,因而要有固定的schema,无法处理动态的xml文件。
首先使用xjc命令,生成java文件
xjc [-options ...]
(生成的文件较多)
- JAXBContext jc = JAXBContext.newInstance(“packageName");
- Unmarshaller unmarshaller = jc.createUnmarshaller();
- Collection collection= (Collection)unmarshaller.unmarshal(new File( "books.xml"));
- CollectionType.BooksType booksType =collection.getBooks();
- List bookList = booksType.getBook();
- for( … ){
- test.jaxb.BookType book =(test.jaxb.BookType) bookList.get(i);
- System.out.println("Book Name: " + book.getName().trim());
- System.out.println("Book ISBN: " + book.getISBN());
- }
JAXBContext jc = JAXBContext.newInstance(“packageName"); Unmarshaller unmarshaller = jc.createUnmarshaller(); Collection collection= (Collection)unmarshaller.unmarshal(new File( "books.xml")); CollectionType.BooksType booksType =collection.getBooks(); List bookList = booksType.getBook(); for( … ){ test.jaxb.BookType book =(test.jaxb.BookType) bookList.get(i); System.out.println("Book Name: " + book.getName().trim()); System.out.println("Book ISBN: " + book.getISBN()); }
补充另一种方法:
据悉dom4j在xml解析方面是性能最好的,hibernate等框架都使用它作为解析的工具。
要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/
目前最新dom4j包下载地址:http://nchc.dl.sourceforge.net/sourceforge/dom4j/dom4j-1.6.1.zip
解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要加入包jaxen-1.1-beta-7.jar
写了简单的dom4j的使用的demo,以备回忆,有些是dom4j的文挡里例子改编的
使用dom4j解析下面的xml文件。
- <?xml version="1.0" encoding="GB2312"?>
- <?xml-stylesheet type="text/xsl" href="students.xsl"?>
- <students>
- <student sn="01">
- <name>张三</name>
- <age>18</age>
- </student>
- <student sn="02">
- <name>李四</name>
- <age>20</age>
- </student>
- </students>
<?xml version="1.0" encoding="GB2312"?> <?xml-stylesheet type="text/xsl" href="students.xsl"?> <students> <student sn="01"> <name>张三</name> <age>18</age> </student> <student sn="02"> <name>李四</name> <age>20</age> </student> </students>
Parse.java
- import java.io.File;
- import org.dom4j.Attribute;
- import org.dom4j.Document;
- import org.dom4j.DocumentException;
- import org.dom4j.Element;
- import org.dom4j.ProcessingInstruction;
- import org.dom4j.VisitorSupport;
- import org.dom4j.io.SAXReader;
- public class Parse {
- public static void main(String[] args) {
- SAXReader reader = new SAXReader();
- File file = new File("src/students.xml");
- try {
- Document doc = reader.read(file);
- doc.accept(new MyVistor());
- } catch (DocumentException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- public static class MyVistor extends VisitorSupport {
- public void visit(Attribute node) {
- System.out.println("Attibute:---" + node.getName() + "="+ node.getValue());
- }
- public void visit(Element node) {
- if (node.isTextOnly()) {
- System.out.println("Element:---" + node.getName() + "="
- + node.getText());
- }else{
- System.out.println("--------" + node.getName() + "-------");
- }
- }
- @Override
- public void visit(ProcessingInstruction node) {
- System.out.println("PI:"+node.getTarget()+" "+node.getText());
- }
- }
- }
import java.io.File; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.ProcessingInstruction; import org.dom4j.VisitorSupport; import org.dom4j.io.SAXReader; public class Parse { public static void main(String[] args) { SAXReader reader = new SAXReader(); File file = new File("src/students.xml"); try { Document doc = reader.read(file); doc.accept(new MyVistor()); } catch (DocumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public static class MyVistor extends VisitorSupport { public void visit(Attribute node) { System.out.println("Attibute:---" + node.getName() + "="+ node.getValue()); } public void visit(Element node) { if (node.isTextOnly()) { System.out.println("Element:---" + node.getName() + "=" + node.getText()); }else{ System.out.println("--------" + node.getName() + "-------"); } } @Override public void visit(ProcessingInstruction node) { System.out.println("PI:"+node.getTarget()+" "+node.getText()); } } }
使用dom4j来将属性写入xml
- import java.io.FileWriter;
- import java.io.IOException;
- import org.dom4j.Document;
- import org.dom4j.DocumentHelper;
- import org.dom4j.Element;
- import org.dom4j.io.OutputFormat;
- import org.dom4j.io.XMLWriter;
- public class DWriter {
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- try {
- XMLWriter writer = new XMLWriter(new FileWriter("src/author.xml"));
- Document doc = createDoc();
- writer.write(doc);
- writer.close();
- // Pretty print the document to System.out
- // 设置了打印的格式,将读出到控制台的格式进行美化
- OutputFormat format = OutputFormat.createPrettyPrint();
- writer = new XMLWriter(System.out, format);
- writer.write(doc);
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- public static Document createDoc() {
- Document doc = DocumentHelper.createDocument();
- Element root = doc.addElement("root");
- Element author1 = root.addElement("author").addAttribute("name",
- "Kree").addAttribute("location", "UK")
- .addText("Kree Strachan");
- Element author2 = root.addElement("author").addAttribute("name", "King")
- .addAttribute("location", "US").addText("King McWrirter");
- return doc;
- }
- }
import java.io.FileWriter; import java.io.IOException; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.OutputFormat; import org.dom4j.io.XMLWriter; public class DWriter { public static void main(String[] args) { // TODO Auto-generated method stub try { XMLWriter writer = new XMLWriter(new FileWriter("src/author.xml")); Document doc = createDoc(); writer.write(doc); writer.close(); // Pretty print the document to System.out // 设置了打印的格式,将读出到控制台的格式进行美化 OutputFormat format = OutputFormat.createPrettyPrint(); writer = new XMLWriter(System.out, format); writer.write(doc); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public static Document createDoc() { Document doc = DocumentHelper.createDocument(); Element root = doc.addElement("root"); Element author1 = root.addElement("author").addAttribute("name", "Kree").addAttribute("location", "UK") .addText("Kree Strachan"); Element author2 = root.addElement("author").addAttribute("name", "King") .addAttribute("location", "US").addText("King McWrirter"); return doc; } }
使用dom4j写入到author.xml文件的内容
- <?xml version="1.0" encoding="UTF-8"?>
- <root>
- <author name="Kree" location="UK">Kree Strachan</author>
- <author name="King" location="US">King McWrirter</author>
- </root>
相关推荐
Java 四种方式操作xml,包括xml,dom,sax,jdom这四种方式的一个简单例子。
java 解析xml 方法 sax jdom dom stAX
XML解析四种解析方式 DOM SAX JDOM DOM4J
java中四种操作(dom、sax、jdom、dom4j)xml方式详解与
用DOM SAX JDom dom4j 对xml文档解析实例 在学习孙鑫老师视频教程,自己照着敲的源码,希望对大家有帮助
JAVA读XML:sax,dom,jdom,dom4j的比较以及选择.doc
总结DOM、SAX、JDOM、DOM4J读写xml文档的多种方法。
操作xml的方式: SAX, DOM, JDOM , DOM4J的比较
介绍了如何通过java来读写xml的方法,其中介绍了几种方法,如:DOM、SAX、JDOM、JAXB、dom4j.
Java解析XML汇总DOM_SAX_JDOM_DOM4j_XPath 实例
XML的四种解析器(dom,sax,jdom,dom4j)原理及性能比较,超详细XML的四种解析器原理及性能比较,超详细
4种最主流、最全面、最详细的生成和解析xml的4种方式,包括Dom,Dom4j,Sax,JDom,读懂了绝对好用xml,非常好的入门项目,而且精心排版,逻辑清晰
用用4中方式(dom4j、jdom、dom、sax)解析xml
java四种xml解析实例和jar包,包括dom,sax,dom4j,jdom等方式 java四种xml解析实例和jar包,包括dom,sax,dom4j,jdom等方式 是学习Java的xml解析的好例子,包括相应的dom4j.jar,jdom.jar等,自己整理的,物超所值啊,...
读取XML文件的四种方法,详细介绍了dom,jdom,dom4j,sax
标准Dom、JDom(为Java提供的解析技术)、Dom4j(优化之后的解析技术)、SAX(大型xml解析的技术) 树模型:DOM、JDOM、Dom4j; 特点:算法丰富、操作比较简单;一次性读取所有内容到内存(不适于大型xml文件解析...
xml doc sax jdom dom4j完全讲解xml doc sax jdom dom4j完全讲解 xml doc sax jdom dom4j完全讲解 xml doc sax jdom dom4j完全讲解 xml doc sax jdom dom4j完全讲解 xml doc sax jdom dom4j完全讲解 xml doc sax ...
有四种方法 DOM DOM4j JDOM SAX 和相对路径的写法 ,代码是有注释的,通用型的……应该对大家有帮助
java读取xml文件的四种方法: 第一种 DOM 实现方法 第二种 DOM4J实现方法 第三种 JDOM实现方法 第四种SAX实现方法