Ⅰ java 解析xml
//注意,以下包必須要導入,否則將導致無法找到相應的對象或方法,我在這里是用jdom實現的對xml文檔的訪問,這幾個包要去網上下,jdk沒有自帶,如果你需要我可以傳給你
//我是用Eclipse建的工程,你自己測試的時候要注意文件路徑或者包的路徑等問題
import java.io.File;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
public class Test {
public static void main(String []args) throws Exception{ //注意這里必須要拋出異常,否則會報錯
SAXBuilder builder = new SAXBuilder();
Document doc = builder.build(new File("test.xml")); //導入xml文件,xml文件名取名為test.xml
Element root=doc.getRootElement(); //獲得根節點
System.out.println("test根結點a、b的屬性值分別是:a='"+root.getAttribute("a").getValue()+"' b='"+root.getAttribute("b").getValue()+"'");
List tempChildren=root.getChildren(); //得到根節點的所有子節點,返回的是List類型的變數
Element temp1=(Element)tempChildren.get(0); //以得到第一個temp結點為例,注意這里必須要強制轉化一下
System.out.println("temp結點a、b的屬性值分別是:a='"+temp1.getAttribute("a").getValue()+"' b='"+temp1.getAttribute("b").getValue()+"'");
Element file=temp1.getChild("file");
System.out.println("file結點id、z的屬性值分別是:id='"+file.getAttribute("id").getValue()+"' z='"+file.getAttribute("z").getValue()+"'");
}
}
//我在本機測試過了一點問題也沒有,如果遇到啥問題到我空間留言哈...
Ⅱ java解析xml常用的幾種方式、
1.DOM(Document Object Model) DOM是用與平台和語言無關的方式表示XML文檔的官方W3C標准。DOM是以層次結構組織的節點或信息片斷的集...
2.SAX(Simple API for XML) SAX處理的優點非常類似於流媒體...
3.JDOM(Java-based Document Object Model)
Ⅲ 在java中解析xml有哪幾種方法
(1)DOM解析
DOM是html和xml的應用程序介面(API),以層次結構(類似於樹型)來組織節點和信息片段,映射XML文檔的結構,允許獲取
和操作文檔的任意部分,是W3C的官方標准
【優點】
①允許應用程序對數據和結構做出更改。
②訪問是雙向的,可以在任何時候在樹中上下導航,獲取和操作任意部分的數據。
【缺點】
①通常需要載入整個XML文檔來構造層次結構,消耗資源大。
【解析詳解】
①構建Document對象:
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = bdf.newDocumentBuilder();
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream(xml文件);
Document doc = bd.parse(is);
②遍歷DOM對象
Document: XML文檔對象,由解析器獲取
NodeList: 節點數組
Node: 節點(包括element、#text)
Element: 元素,可用於獲取屬性參數
(2)SAX(Simple API for XML)解析
流模型中的"推"模型分析方式。通過事件驅動,每發現一個節點就引發一個事件,事件推給事件處理器,通過回調方法
完成解析工作,解析XML文檔的邏輯需要應用程序完成
【優勢】
①不需要等待所有數據都被處理,分析就能立即開始。
②只在讀取數據時檢查數據,不需要保存在內存中。
③可以在某個條件得到滿足時停止解析,不必解析整個文檔。
④效率和性能較高,能解析大於系統內存的文檔。
【缺點】
①需要應用程序自己負責TAG的處理邏輯(例如維護父/子關系等),文檔越復雜程序就越復雜。
②單向導航,無法定位文檔層次,很難同時訪問同一文檔的不同部分數據,不支持XPath。
【原理】
簡單的說就是對文檔進行順序掃描,當掃描到文檔(document)開始與結束、元素(element)開始與結束時通知事件
處理函數(回調函數),進行相應處理,直到文檔結束
【事件處理器類型】
①訪問XML DTD:DTDHandler
②低級訪問解析錯誤:ErrorHandler
③訪問文檔內容:ContextHandler
【DefaultHandler類】
SAX事件處理程序的默認基類,實現了DTDHandler、ErrorHandler、ContextHandler和EntityResolver介面,通常
做法是,繼承該基類,重寫需要的方法,如startDocument()
【創建SAX解析器】
SAXParserFactory saxf = SAXParserFactory.newInstance();
SAXParser sax = saxf.newSAXParser();
註:關於遍歷
①深度優先遍歷(Depthi-First Traserval)
②廣度優先遍歷(Width-First Traserval)
(3)JDOM(Java-based Document Object Model)
Java特定的文檔對象模型。自身不包含解析器,使用SAX
【優點】
①使用具體類而不是介面,簡化了DOM的API。
②大量使用了Java集合類,方便了Java開發人員。
【缺點】
①沒有較好的靈活性。
②性能較差。
(4)DOM4J(Document Object Model for Java)
簡單易用,採用Java集合框架,並完全支持DOM、SAX和JAXP
【優點】
①大量使用了Java集合類,方便Java開發人員,同時提供一些提高性能的替代方法。
②支持XPath。
③有很好的性能。
【缺點】
①大量使用了介面,API較為復雜。
(5)StAX(Streaming API for XML)
流模型中的拉模型分析方式。提供基於指針和基於迭代器兩種方式的支持,JDK1.6新特性
【和推式解析相比的優點】
①在拉式解析中,事件是由解析應用產生的,因此拉式解析中向客戶端提供的是解析規則,而不是解析器。
②同推式解析相比,拉式解析的代碼更簡單,而且不用那麼多庫。
③拉式解析客戶端能夠一次讀取多個XML文件。
④拉式解析允許你過濾XML文件和跳過解析事件。
【簡介】
StAX API的實現是使用了Java Web服務開發(JWSDP)1.6,並結合了Sun Java流式XML分析器(SJSXP)-它位於
javax.xml.stream包中。XMLStreamReader介面用於分析一個XML文檔,而XMLStreamWriter介面用於生成一個
XML文檔。XMLEventReader負責使用一個對象事件迭代子分析XML事件-這與XMLStreamReader所使用的游標機制
形成對照。
Ⅳ Java裡面怎麼解析xml文件的內容
1.文件位置
2.創建文檔對象
3.獲得幾點
4.遍歷節點,得到內容
// 1文件位置
String path =TestXML.class.getResource("/").getPath()+"com/xsh/u1/goods.xml"
//2.1創建文檔對象\
DocumentBuilderFactory dbf=DocumentBuilderFctory.newIntance();
DocumentBuilder db=dbf.newDocumentBuilder();
//2.2創建XML對象
Document doc=db.parse(path);
//3.
Nodelist list=doc.getElementsByTagName("name");//得到一個元素的列表
//4遍歷節點
for(int i=0;i<list.length;i++){
}
public void addone(String name,String password)
{
//解析XML文件
DocumentBuilderFactory dvf=DocumentBuilderFactory.newInstance();
try {
DocumentBuilder db=dvf.newDocumentBuilder();
Document doc= (Document) db.parse(path);
//在Document實例中先創建元素
Element naElement=doc.createElement("NAME");
naElement.setTextContent(name);
naElement.setAttribute("PASSOWRD",password);
//得到節點
Element ROOT=doc.getDocumentElement();
//添加節點,把之前創建的元素放到該節點的只節點上,也就是把創建的元素成為該節點的子元素
ROOT.appendChild(naElement);
//寫入xml文件中
Source xmlSource = new DOMSource(doc);
//工廠類
TransformerFactory factory = TransformerFactory.newInstance();
//轉換器
Transformer transformer = factory.newTransformer();
//設置輸出格式和屬性
transformer.setOutputproties();
//創建結果樹
Result result = new StreamResult(new File(path));
//xmlSource=new DOMSource(Document);
transformer.transform(xmlSource, result);
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch ( e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (TransformerException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Ⅳ java xml報文解析,下面是從其它平台傳過來的一個xml報文,小弟從來沒涉及這塊,求解析方法,求大神指點
自己去搜一個叫dom4j的東西……這是java的一個第三方工具包,用來解析xml的
Ⅵ java 怎麼解析xml數據包數據 將xml各節點下的數據取出來
xml解析方法可以說有4種工具;
jdom,dom,sax,一般比較好懂的就是jdom,你網路jdom就有很多,網路文庫也可以
Ⅶ Java裡面怎麼解析xml文件的內容
import java.io.File; import java.util.Iterator; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Dom4JReader { public Dom4JReader() {}/**** @Function 獲取xml文件里符合要求的數據*/public void getDom() { SAXReader sr = new SAXReader();try {//獲取applicationContext.xml文件的對象 Document doc = sr.read(new File("applicationContext.xml")); //獲得跟節點 Element root = doc.getRootElement(); //// 枚舉所有子節點 for (Iterator i = root.elementIterator("bean"); i.hasNext();) { //獲取bean節點 Element bean = (Element) i.next(); // 枚舉名稱為bean的節點 for (Iterator j = bean.attributeIterator(); j.hasNext();) { //獲取bean節點的所有屬性 Attribute attr = (Attribute) j.next(); //判斷屬性的值如果為fileUploadBo if (attr.getText().equals("fileUploadBo")) { //列印出這個bean節點的所有信息 System.out.println(bean.asXML());}}}} catch (DocumentException e) { e.printStackTrace();}}}這段代碼要執行的話,要導入dom4j的包,還有 //獲取applicationContext.xml文件的對象
Ⅷ Java 如何解析XML
package xml;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
public class xml {
public static void main(String[] args) {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse("d:/xml.xml");
//得到根節點
Element root = doc.getDocumentElement();
//得到所有Tree
NodeList nl = root.getElementsByTagName("Tree");
//得到第一個TRee節點
Element e = (Element) nl.item(0);
//刪除節點,此處沒用,給你留著參考的.
/*
Element stu2 = (Element)(root.getElementsByTagName("student").item(1));
root.removeChild(stu2);
*/
//增加節點
Element entry = doc.createElement("Entry");
entry.setAttribute("id", "2");
entry.setAttribute("parentId", "0");
entry.setAttribute("name", "li");
//在tree元素下增加元素
e.appendChild(entry);
//回寫
DOMSource ds = new DOMSource(doc);
StreamResult sr = new StreamResult(new File("d:/xml2.xml"));
TransformerFactory.newInstance().newTransformer().transform(ds, sr);
System.out.println("ok");
} catch (Exception e) {
e.printStackTrace();
}
}
}
Ⅸ java 解析xml
Ⅹ java的xml的解析方式有什麼,他們的解析流程是怎麼樣的,有什麼區別
答:4種。(或者說是兩種,因為JDOM和DOM4J是DOM的兩個特殊情況)
1.SAX解析
解析方式是事件驅動機制!
SAX解析器,逐行讀取XML文件解析,每當解析到一個標簽的開始/結束/內容/屬性時,觸發事件。
可以在這些事件發生時,編寫程序進行相應的處理。
優點:
分析能夠立即開始,而不是等待所有的數據被處理。
逐行載入,節省內存,有助於解析大於系統內存的文檔。
有時不必解析整個文檔,它可以在某個條件得到滿足時停止解析。
缺點:
1.單向解析,無法定位文檔層次,無法同時訪問同一個文檔的不同部分數據(因為逐行解析,當解析第n行時,第n-1行)已經被釋放了,無法再對其進行操作)。
2. 無法得知事件發生時元素的層次, 只能自己維護節點的父/子關系。
3. 只讀解析方式, 無法修改XML文檔的內容。
2. DOM解析
是用與平台和語言無關的方式表示XML文檔的官方W3C標准,分析該結構通常需要載入整個 文檔和內存中建立文檔樹模型。程序員可以通過操作文檔樹, 來完成數據的獲取 修改 刪除等。
優點:
文檔在內存中載入, 允許對數據和結構做出更改。訪問是雙向的,可以在任何時候在樹中雙向解析數據。
缺點:
文檔全部載入在內存中 , 消耗資源大。
3. JDOM解析
目的是成為Java特定文檔模型,它簡化與XML的交互並且比使用DOM實現更快。由於是第一 個Java特定模型,JDOM一直得到大力推廣和促進。
JDOM文檔聲明其目的是「使用20%(或更少)的精力解決80%(或更多)Java/XML問題」 (根據學習曲線假定為20%)
優點:
使用具體類而不是介面,簡化了DOM的API。
大量使用了Java集合類,方便了Java開發人員。
缺點:
沒有較好的靈活性。
性能不是那麼優異。
4. DOM4J解析
它是JDOM的一種智能分支。它合並了許多超出基本XML文檔表示的功能,包括集成的XPath 支持、XML Schema支持以及用於大文檔或流化文檔的基於事件的處理。它還提供了構建文檔表示的選項, DOM4J是一個非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一 個開放源代碼的軟體。如今你可以看到越來越多的Java軟體都在使用DOM4J來讀寫XML。
目前許多開源項目中大量採用DOM4J , 例如:Hibernate。