日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

简单使用JDOM解析XML

發(fā)布時間:2024/4/17 asp.net 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 简单使用JDOM解析XML 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?

簡單使用JDOM解析XML

  • 博客分類:
  • xml
XMLJava編程ASPVB

使用JDOM解析XML
一、前言
????JDOM是Breet?Mclaughlin和Jason?Hunter兩大Java高手的創(chuàng)作成果,2000年初,JDOM作為一個開放源代碼項目正式開始研發(fā)。JDOM是一種解析XML的Java工具包。?
????DOM適合于當(dāng)今流行的各種語言,包括Java,JavaScripte,VB,VBScript,Perl,C,C++等。它了為HTML和XML文檔提供了一個可應(yīng)用于不同平臺的編程接口。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的詳細(xì)技術(shù)信息。

???DOM的設(shè)計為了適用于不同的語言,它保留了不同語言中非常相似的API。但是它并不適合于Java編程者的習(xí)慣。而JDOM作為一種輕量級API被制定,它最核心的要求是以Java為中心,只適合于Java語言,它遵循DOM的接口主要規(guī)則,除去了DOM中為了兼容各語言而與Java習(xí)慣的不同。

二、使用JDOM的前提條件
???須要有SAX、DOM解析器的類文件,JDOM只是一種適合Java程序員來使用的Java?XML解析器,目前流行的Java?XML解析器還有:Apache?Xerces?Java、JAXP。
Xerces?Java解析器是完全用Java編寫的XML解析器,最新版本是2.5,它支持以下標(biāo)準(zhǔn)和API:

(1)?XML1.0規(guī)范(第二版本)

(2)?XML命名空間規(guī)范

(3)?DOM2核心標(biāo)準(zhǔn)規(guī)范

(4)?SAX2核心擴展

(5)?JAXP1.2?:是Sun提供的使用Java處理XML的接口API。

(6)?XML?Schema結(jié)構(gòu)和數(shù)據(jù)類型標(biāo)準(zhǔn)??

??????還有最好的是它開放源代碼,我們可以在http://xml.apache.org/dist/xerces-j/?處去下載。下載文件Xerces-J-bin.2.5.0.zip。
解壓下載文件,得到四個壓縮包加到項目的路徑中(其實不要全加,但不熟的情況下考慮這么做)。
JDOM的二進(jìn)制版本下載:http://www.jdom.org/downloads/index.html
把解壓后的jdom.jar文件加到項目的類路徑中,另外便于調(diào)試,還要下載它的源代碼。

三、使用JDOM解析XML
?????好了,現(xiàn)在該是正題了。下面通過一個簡單的例子說明一下怎么用JDOM這一適合Java程序員習(xí)慣的工具包來解析XML文檔。
為了簡單,我用了如下XML作為要解析的XML文件:

<?xml?version="1.0"?encoding="utf-8"?>
<books>
???<book?email="zhoujunhui">
?????<name>rjzjh</name>
?????<price>60.0</price>
??</book>
</books>
夠簡單的吧,但它對于我們關(guān)心的東西都有了,子節(jié)點,屬性。
下面是用于解析這個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行代碼,現(xiàn)在我對代碼解釋一下:
四、解釋代碼
引用的類:
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);?這表示使用的是默認(rèn)的解析器
(2)得到Document,我們以后要進(jìn)行的所有操作都是對這個Document操作的:
????????Document?doc=builder.build(xmlpath);
(3)得到根元素:
????????Element?books=doc.getRootElement();
在JDOM中所有的節(jié)點(DOM中的概念)都是一個org.jdom.Element類,當(dāng)然他的子節(jié)點也是一個org.jdom.Element類。
(4)得到元素(節(jié)點)的集合:
??????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文檔中進(jìn)行修改
(9)保存Document的修改到XML文件中:
???XMLOutputter?outputter=new?XMLOutputter();
????outputter.output(doc,new?FileOutputStream(xmlpath));

我們先要有一個XMLOutputter類,再把已經(jīng)修改了的Document保存進(jìn)XML文檔中。
到此。用JDOM解析和處理XML文檔講解完了,麻雀雖小,五臟俱全。現(xiàn)在已對JDOM有個整體上的概念了吧。

文章來自:http://www.java3z.com/cwbwebhome/article/article2a/217.jsp?id=106

總結(jié)

以上是生活随笔為你收集整理的简单使用JDOM解析XML的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 少妇系列在线观看 | 玉米地疯狂的吸允她的奶视频 | 秋霞国产午夜精品免费视频 | 毛片9 | 亚洲一区二区免费视频 | www.com日本 | 少妇裸体淫交视频免费看高清 | 婷婷亚洲精品 | 亚洲国产欧美精品 | 亚洲一区无 | 日本福利在线观看 | 黄色av一级| 国产精品高潮呻吟久久久 | 麻豆免费电影 | 国产色视频一区二区三区qq号 | 色花堂在线| 鲁丝av | 91资源站| 精品一区二区免费视频 | 精品成人一区二区三区久久精品 | 国产视频一区二区三区四区五区 | 欧美中文字幕第一页 | 大陆熟妇丰满多毛xxxⅹ | 国产 中文 字幕 日韩 在线 | 亚洲视频网址 | 美女黄色录像 | 另类二区| 可以在线看的av | 日本无遮羞调教打屁股网站 | 亚洲av无码精品色午夜果冻不卡 | 欧美精品乱码99久久蜜桃 | 久久中字 | 一女三黑人理论片在线 | 包射屋 | 欧美日韩综合视频 | 性欧美另类| 一区www| 卡一卡二在线视频 | 深夜福利亚洲 | 天堂视频网 | 国产一区二区三区精品愉拍 | japanese在线| 青青久久国产 | 国产毛片久久久久久国产毛片 | 国产精品久久久精品三级 | 国产成人综合在线视频 | 亚洲欧美日韩一区 | 91视频在线看| 播播激情网 | 18成人免费观看视频 | 亚洲欧美日韩天堂 | 久草aⅴ| 中文字幕一区在线观看 | 国产精品成人午夜视频 | 国产成人麻豆免费观看 | 亚洲第一综合网 | 精品丰满人妻无套内射 | 日韩免费在线视频观看 | 国产性猛交╳xxx乱大交 | 有声小说 成人专区 | 亚洲精品喷潮一区二区三区 | 一区二区三区四区欧美 | 国产69页| 免费啪啪网 | 天堂视频免费在线观看 | 18岁免费观看电视连续剧 | 青青草国产在线 | 国产videos| 嫩草一区二区 | 中文幕无线码中文字夫妻 | 天堂成人在线观看 | 精品中文字幕视频 | 国产精品视频合集 | 日韩av无码中文字幕 | caoprom在线视频 | 777精品 | 中文字幕乱码亚洲无线三区 | 天天摸天天做天天爽 | 国产又爽又黄游戏 | 国产精品传媒在线观看 | 夜色网 | 免费簧片在线观看 | www.99视频 | 日本人妻熟妇久久久久久 | 在线亚洲+欧美+日本专区 | 国产视频在线观看视频 | 久草国产在线视频 | 一级艳片新婚之夜 | 国产麻豆免费视频 | 欧美老肥熟 | 97精品超碰一区二区三区 | 性欧美ⅹxxxx极品护士 | 欧美一区二区三区在线看 | 香蕉视频网址 | 亚洲成人日韩 | 久久欧美视频 | 中文字幕乱码在线人视频 | 国产成人精品亚洲男人的天堂 | 中文字幕在线2018 |