av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Java實現解析并生成xml原理實例詳解

瀏覽:3日期:2022-08-31 11:35:46

XML解析:

* 解析xml可以做: * 如果xml作為配置文件:讀取 * 如果xml作為傳輸文件:寫,讀

xml解析思想:

* DOM:將文檔加載進內存,形成一顆dom樹(document對象),將文檔的各個組成部分封裝為一些對象。 * 優點:因為,在內存中會形成dom樹,可以對dom樹進行增刪改查。 * 缺點:dom樹非常占內存,解析速度慢。

DocumentElementTextAttributeComment

* SAX:逐行讀取,基于事件驅動* 優點:不占內存,速度快* 缺點:只能讀取,不能回寫

xml常用的解析器:

* JAXP:sun公司提供的解析。支持dom和sax。(不常用) * JDOM: * DOM4J:dom for java民間方式,但是是事實方式。非常好。 支持dom

1.導入jar包 dom4j.jar

2.創建解析器

SAXReader reader = new SAXReader();

3.解析xml 獲得document對象

Document document = reader.read(url);

* XPATH:專門用于查詢 * 定義了一種規則。 * 使用的方法: * selectSingleNode(): * selectNodes():

使用步驟:

1、注意:要導包 jaxen...jar

2、創建解析器

SAXReader reader = new SAXReader();

3、解析xml 獲得document對象

Document document = reader.read(url);

* 解析XML:

// 1、得到某個具體的節點內容:第2本書的書名--》葵花寶典

// 2、遍歷所有元素節點

XPath:

// nodename 選取此節點。 // / 從根節點選取。 // // 從匹配選擇的當前節點選擇文檔中的節點,而不考慮它們的位置。 // .. 選取當前節點的父節點。 // @ 選取屬性。 // [@屬性名] 屬性過濾 // [標簽名] 子元素過濾

例子:

/* demo.xml<?xml version='1.0' encoding='UTF-8'?><books> <book name='Harry Potter'> <author>J.K. Rowling</author> <price>29.90$</price> </book> <book name='冰與火之歌'> <author>馬丁</author> <price>28.90$</price> </book></books>*/@Testpublic void test1() throws DocumentException{ SAXReader reader = new SAXReader(); Document doc = reader.read('./src/demo.xml'); Element root = doc.getRootElement(); Element book1 = root.element('book'); System.out.println(book1.getPath()); System.out.println(book1.elementText('price')); List<?> list = root.elements('book'); Element book2 = (Element) list.get(1); System.out.println(book2.attributeValue('name')); for(Iterator<?> it = book1.elementIterator();it.hasNext() ; ){ Element ele = (Element) it.next(); System.out.println(ele.getName()+' : '+ele.getText()); }}@Test public void test2() throws Exception{//使用 XPath,只用于快速查詢,需要用jaxen...jar包 SAXReader reader = new SAXReader(); Document doc = reader.read(new File('src/demo.xml')); Node node = doc.selectSingleNode('/books/book[2]/author');//需要jaxen.jar包 String s = node.getText(); System.out.println(s); node = doc.selectSingleNode('/books/book[2]/@name'); s = node.getText(); System.out.println(s); List<Node> booknames = doc.selectNodes('/books//@name'); for (Node node1 : booknames) { System.out.println(node1.getText()); } List<?> nodes = doc.selectNodes('/books/*/*'); for (int i=0; i<nodes.size(); ++i){ Node node1 = (Node) nodes.get(i); System.out.println(node1.getName() + ': ' + node1.getText()); }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 一级毛片免费 | 羞羞的视频网站 | 国产欧美精品一区 | 亚洲97| 日一区二区三区 | 欧美一级片在线看 | 99综合在线| 狠狠躁天天躁夜夜躁婷婷老牛影视 | 国产一级片av| 大乳boobs巨大吃奶挤奶 | gogo肉体亚洲高清在线视 | 一区在线视频 | 久久久久国 | 国产精品久久久久久亚洲调教 | 91在线精品视频 | 久久久高清 | 一区二区三区精品 | 日韩精品视频在线 | 精品国产伦一区二区三区观看体验 | 一区二区三区在线播放视频 | 91精品国产日韩91久久久久久 | 欧美精品福利 | 日本一区二区高清不卡 | 国产高清一区二区三区 | 欧美久久一区 | 国产欧美精品区一区二区三区 | 亚洲欧美一区二区三区在线 | 久久国产精品精品国产色婷婷 | 欧美在线a | 亚洲一区在线播放 | 天天色影视综合 | 欧美一页 | 91麻豆产精品久久久久久 | 一区欧美 | 国产精品污www在线观看 | 91精品中文字幕一区二区三区 | 久久精品在线 | 久久久久久国产 | 久久久国产一区 | 男女爱爱网站 | 欧美11一13sex性hd|