- 浏览: 472148 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
bewithme:
我把一个透明背景的PNG画到了另外一张图片上,为啥透明背景就变 ...
Java绘制PNG图片时的黑色背景问题 -
davidwkj:
Y坐标的公式不对。算出来的值是错的!!!!!!!!!!!!!! ...
两条线段是否相交,计算交点公式。 -
zhang9181156:
茅塞顿开哈,感谢
android--相机开发 -
leecinwell:
哈
Android条用照相机,实现可剪切功能 -
life_菜鸟飞:
非常感谢作者这么详细的讲解,自己也动手实践了一下,发现前面几个 ...
android--相机开发
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 version="1.0" encoding="UTF-8"?>
- <sys-config>
- <jdbc-info>
- <driver-class-name>oracle.jdbc.driver.OracleDriver</driver-class-name>
- <url>jdbc:oracle:thin:@localhost:1521:database</url>
- <user-name>why</user-name>
- <password>why</password>
- </jdbc-info>
- <provinces-info>
- <province id="hlj" name="黑龙江">
- <city id="harb">哈尔滨</city>
- <city id="nj">嫩江</city>
- </province>
- <province id="jl" name="吉林"></province>
- </provinces-info>
- </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文件的例子,比起文字描述更直观一些吧:
- package com.why.jdom;
- import java.io.IOException;
- import java.util.Iterator;
- import java.util.List;
- import org.jdom.input.SAXBuilder;
- import org.jdom.xpath.XPath;
- import org.jdom.Document;
- import org.jdom.Element;
- import org.jdom.JDOMException;
- public class ReadXML {
- /**
- * @param args
- */
- public static void main(String[] args) {
- SAXBuilder sax = new SAXBuilder();
- try {
- Document doc = sax.build("src/config.xml");
- Element rootEle = doc.getRootElement();
- Element driverClassNameElement = (Element)XPath.selectSingleNode(rootEle, "//sys-config/jdbc-info/driver-class-name");
- String driverClassName = driverClassNameElement.getText();
- System.out.println("driverClassName = " + driverClassName);
- List provinceList = XPath.selectNodes(rootEle, "//sys-config/provinces-info/province");
- for(Iterator it = provinceList.iterator();it.hasNext();){
- Element provinceEle = (Element)it.next();
- String proId = provinceEle.getAttributeValue("id");
- String proName = provinceEle.getAttributeValue("name");
- System.out.println("provinceId = " + proId + " provinceName = " + proName);
- List cityEleList = (List)provinceEle.getChildren("city");
- for(Iterator cityIt = cityEleList.iterator();cityIt.hasNext();){
- Element cityEle = (Element)cityIt.next();
- String cityId = cityEle.getAttributeValue("id");
- String cityName = cityEle.getText();
- System.out.println(" cityId = " + cityId + " cityName = " + cityName);
- }
- }
- } catch (JDOMException e) {
- // TODO 自动生成 catch 块
- e.printStackTrace();
- } catch (IOException e) {
- // TODO 自动生成 catch 块
- e.printStackTrace();
- }
- }
- }
二、写xml文件
写xml文件与读取xml文件的操作类似,利用 org.jdom.output.XMLOutputter 就可以将处理好的xml输出到文件了。可以设置文件的编码方式,不过一般使用UTF-8就可以了。代码如下:
- package com.why.jdom;
- import java.io.FileNotFoundException;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import org.jdom.Document;
- import org.jdom.Element;
- import org.jdom.output.XMLOutputter;
- public class WriteXML {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO 自动生成方法存根
- Element rootEle = new Element("sys-config");
- Element provincesEle = new Element("provinces-info");
- Element provinceEle = new Element("province");
- provinceEle.setAttribute("id","hlj");
- provinceEle.setAttribute("name","黑龙江省");
- Element cityEle1 = new Element("city");
- cityEle1.setAttribute("id","harb");
- cityEle1.addContent("哈尔滨");
- Element cityEle2 = new Element("city");
- cityEle2.setAttribute("id","nj");
- cityEle2.addContent("嫩江");
- provinceEle.addContent(cityEle1);
- provinceEle.addContent(cityEle2);
- provincesEle.addContent(provinceEle);
- rootEle.addContent(provincesEle);
- Document doc = new Document(rootEle);
- XMLOutputter out = new XMLOutputter();
- // out.setFormat(Format.getCompactFormat().setEncoding("GBK"));//设置文件编码,默认为UTF-8
- String xmlStr = out.outputString(doc);
- System.out.println(xmlStr);
- try {
- out.output(doc, new FileOutputStream("c:/test.xml"));
- } catch (FileNotFoundException e) {
- // TODO 自动生成 catch 块
- e.printStackTrace();
- } catch (IOException e) {
- // TODO 自动生成 catch 块
- e.printStackTrace();
- }
- }
- }
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-->
发表评论
-
Java绘制PNG图片时的黑色背景问题
2013-03-13 16:09 46291. 生成png图片 int width = ... -
Swing开发时必定会碰到的11个问题及解决方案
2013-03-07 09:50 19041.JTable ,JTable如何在内容里面存放组件(下拉 ... -
Java新浪微博客户端开发第六步(完结&&开源)
2012-11-07 16:04 1313这次所达到的:修 ... -
Java新浪微博客户端开发第四、五步
2012-11-07 16:04 12700、Main:主函数入 ... -
Java新浪微博客户端开发第二、三步
2012-11-07 16:03 1453MainDialog:此微博客户端的界面,分上下 ... -
Java新浪微博客户端开发第一步
2012-11-07 15:50 1516到http://open.weibo.com/w ... -
JTree用法及JTree使用经验总结
2011-11-29 13:35 1266import java.awt.Dimension; ... -
java解析xml文件四种方式
2011-11-29 13:27 10751.介绍 1)DOM(JAXP Cri ... -
JFrame设置大小和显示setSize和pack
2011-11-25 15:29 2413/* * 总结: ... -
java web start 的相关配置
2011-10-27 10:54 1301部署 五、把包放到服务器webapps目录中 ... -
JAVA文件打包成可执行文件
2011-10-27 10:53 1982一、编写程序Test.java并编译为Test.clas ... -
一个关于java继承的题目
2011-09-28 09:35 1906复制来的: 一个关于java继承的题目,跟大家分享下。题目如 ... -
ArrayList、 Vector 、LinkedList区别与用法
2011-09-27 17:16 4282一: 最近用到了,所 ... -
我对Swing各组件的认识
2011-06-30 10:08 10652010-09-28 我对Swing各组件的认识 注:整 ... -
JDialog关闭的问题
2011-06-12 16:30 5783今天用到JDialog,突然发现,点击关闭后不能完全退出, ... -
关于JComboBox触发事件总是执行两次的问题
2011-05-11 17:46 6703今天用到JcomBox,在JComboBox的监听事件时总 ... -
关于JPanel的布局显示问题
2011-05-09 15:07 3529关于JPanel的布局显示: 前几天写一个小程序,用到 ... -
JSplitPane按比例分割的问题
2011-05-09 10:51 1333JSplitPane看似比Delphi的spliter难用许多 ... -
JTree 和 JTable 的综合应用 Demo
2011-04-29 09:22 1831本文是一个 JTree 和 JTable 的综合应用 Demo ... -
JSplitPane按比例分割的问题
2011-04-28 08:51 6962JSplitPane看似比Delphi的spliter难用许多 ...
相关推荐
Java JDOM解析XML是Java开发中处理XML文档的一种方法,JDOM全称为Java Document Object Model,它是一个基于Java语言的API,用于创建、修改和读取XML文档。JDOM为XML处理提供了一种高效且方便的解决方案,尤其适用于...
org.jdom.adapters包含了与dom适配的java类 org.jdom.filter包含了xml文档的过滤器类 org.jdom.input包含了读取xml文档的类 org.jdom.output包含了写入xml文档的类 org.jdom.transform包含了将jdomxml 文档接口转换...
在Java中,JDOM(Java Document Object Model)是一个流行的选择来解析和操作XML文档。它提供了一个纯Java的API,使开发者能够高效地读取、创建和修改XML内容。 ### JDOM基本概念 1. **Document对象**:JDOM的核心...
JDOM是Java中专门用来解析和操作XML的一个库,它提供了一种高效且方便的方式来处理XML文档。本实例将深入讲解如何使用JDOM进行XML解析。 首先,我们需要在项目中引入JDOM的类库。JDOM官方网站提供了不同版本的JDOM ...
**XML解析方式** 1. **DOM解析**:DOM解析器将整个XML文档加载到内存中,形成一个树形结构,称为DOM树。这种方式方便了对XML文档的随机访问,但可能会消耗大量内存,尤其对于大型文档。 2. **SAX解析**:SAX...
在Java中,JDOM(Java Document Object Model)是一个流行的选择,用于解析和创建XML文档。JDOM提供了方便的方式来处理XML文档,使得开发者能够更高效地操作XML数据。 **一、JDOM的基本概念** 1. **Document对象**...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域...在实际项目中,根据需求和性能考虑,开发者可能会选择JDOM、DOM、SAX或StAX等不同XML解析库。
JDOM,全称Java Document Object Model,是专门为Java设计的一个解析XML的API,它提供了方便的构建和操作XML文档的方法。 JDOM的优势在于它完全基于Java,因此可以充分利用Java的强大功能,如异常处理、内存管理等...
1. **DOM(Document Object Model)**:DOM是一种树形结构,将XML文档解析为一系列的对象,这些对象可以被Java程序访问和操作。JDOM就是基于DOM模型的实现。 2. **Element**: 在JDOM中,`Element`类代表XML文档中的...
总结,JDOM作为Java处理XML的一种工具,提供了简洁的API来生成和解析XML文档。无论是创建新的XML文件还是从现有文件中提取数据,JDOM都能以直观的方式实现。通过以上示例,我们可以看出JDOM的强大之处在于其灵活性和...
对于XML解析,JDOM提供了两种方式:SAX(Simple API for XML)和DOM(Document Object Model)。SAX是一种事件驱动的解析器,适用于处理大型XML文件,因为它不会一次性加载整个文档到内存。DOM则是基于树的模型,会...
JDOM是Java中一个专门用来处理XML的库,它提供了一种高效、灵活且完全符合Java语言习惯的方式来读取、写入和操作XML文档。下面我们将详细探讨JDOM解析本地XML的相关知识点。 首先,JDOM的核心概念包括`Element`、`...
总的来说,JDOM-1.0是Java程序员处理XML的强大工具,通过其简洁的API,使得XML的解析、操作和生成变得简单易行。无论是在构建复杂的应用程序还是进行数据交换,JDOM都能提供可靠的解决方案。在实际开发中,根据项目...
JDOM提供了SAXBuilder和DOMBuilder,分别用于基于SAX(Simple API for XML)和DOM的XML解析。 使用DOM解析XML的基本步骤如下: 1. 加载XML文件:通过`javax.xml.parsers.DocumentBuilderFactory`创建`...
1. **SAXBuilder**:通过监听XML解析过程中的事件来构建JDOM树。 2. **DOMBuilder**:一次性加载整个XML文档到内存,生成Document对象。 **创建XML文档** 使用JDOM创建XML文档涉及以下几个步骤: 1. 创建`...
总结,JDOM 2.0.6.jar是一个强大的XML处理库,它为Java开发者提供了简洁且高效的API来读取、写入和操作XML文档。在实际项目中,结合使用SAXBuilder、Document、Element和Attribute等类,你可以轻松地完成XML相关的...
在Java中,使用JDOM进行XML操作主要涉及以下几个核心概念和步骤: 1. **构建XML文档**:首先,我们需要创建一个`DocumentBuilderFactory`实例,然后通过`newDocumentBuilder()`方法获取`DocumentBuilder`。利用`...
JDOM是Java Document Object Model的简称,它提供了一种高效、便捷的方式来创建和操作XML文档。 JDOM 1.0是JDOM的一个早期版本,它为开发者提供了全面的API来处理XML文档。这个版本支持XML的读取、写入和修改,同时...
本篇文章将深入探讨使用JDOM进行XML解析的过程。 JDOM是一个纯Java的XML处理库,它提供了一个简单、高性能的方式来创建、修改和读取XML文档。JDOM通过构建DOM(Document Object Model)树来解析XML,DOM是一种与...