当前位置:编程学习 > XML/UML >>

java解析xml的几种方式

java解析xml的几种方式

 


DOM


DOM的全称是Document ObjectModel,也即文档对象模型。在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作。通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,因此,这种利用DOM接口的机制也被称作随机访问机制。

DOM接口提供了一种通过分层对象模型来访问XML文档信息的方式,这些分层对象模型依据XML的文档结构形成了一棵节点树。无论XML文档中所描述的是什么类型的信息,即便是制表数据、项目列表或一个文档,利用DOM所生成的模型都是节点树的形式。也就是说,DOM强制使用树模型来访问XML文档中的信息。由于XML本质上就是一种分层结构,所以这种描述方法是相当有效的。

DOM树所提供的随机访问方式给应用程序的开发带来了很大的灵活性,它可以任意地控制整个XML文档中的内容。然而,由于DOM分析器把整个XML文档转化成DOM树放在了内存中,因此,当文档比较大或者结构比较复杂时,对内存的需求就比较高。而且,对于结构复杂的树的遍历也是一项耗时的操作。所以,DOM分析器对机器性能的要求比较高,实现效率不十分理想。不过,由于DOM分析器所采用的树结构的思想与XML文档的结构相吻合,同时鉴于随机访问所带来的方便,因此,DOM分析器还是有很广泛的使用价值的。

Java代码 

1.  import java.io.File; 

2.   

3.  import javax.xml.parsers.DocumentBuilder; 

4.  import javax.xml.parsers.DocumentBuilderFactory; 

5.   

6.  import org.w3c.dom.Document; 

7.  import org.w3c.dom.Element; 

8.  import org.w3c.dom.NodeList; 

9.   

10. public class DomTest1 

11. { 

12.     public static void main(String[] args) throws Exception 

13.     { 

14.         // step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器) 

15.         DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 

16.          

17. //      System.out.println("class name: " + dbf.getClass().getName()); 

18.          

19.         // step 2:获得具体的dom解析器 

20.         DocumentBuilder db = dbf.newDocumentBuilder(); 

21.          

22. //      System.out.println("class name: " + db.getClass().getName()); 

23.          

24.         // step3: 解析一个xml文档,获得Document对象(根结点) 

25.         Document document = db.parse(new File("candidate.xml")); 

26.          

27.         NodeList list = document.getElementsByTagName("PERSON"); 

28.          

29.         for(int i = 0; i < list.getLength(); i++) 

30.         { 

31.             Element element = (Element)list.item(i); 

32.              

33.             String content = element.getElementsByTagName("NAME").item(0).getFirstChild().getNodeValue(); 

34.              

35.             System.out.println("name:" + content); 

36.              

37.             content = element.getElementsByTagName("ADDRESS").item(0).getFirstChild().getNodeValue(); 

38.              

39.             System.out.println("address:" + content); 

40.              

41.             content = element.getElementsByTagName("TEL").item(0).getFirstChild().getNodeValue(); 

42.              

43.             System.out.println("tel:" + content); 

44.              

45.             content = element.getElementsByTagName("FAX").item(0).getFirstChild().getNodeValue(); 

46.              

47.             System.out.println("fax:" + content); 

48.              

49.             content = element.getElementsByTagName("EMAIL").item(0).getFirstChild().getNodeValue(); 

50.              

51.             System.out.println("email:" + content); 

52.              

53.             System.out.println("--------------------------------------"); 

54.         } 

55.     } 

56. } 

Java代码 

1.  import java.io.File; 

2.   

3.  import javax.xml.parsers.DocumentBuilder; 

4.  import javax.xml.parsers.DocumentBuilderFactory; 

5.   

6.  import org.w3c.dom.Attr; 

7.  import org.w3c.dom.Comment; 

8.  import org.w3c.dom.Document; 

9.  import org.w3c.dom.Element; 

10. import org.w3c.dom.NamedNodeMap; 

11. import org.w3c.dom.Node; 

12. import org.w3c.dom.NodeList; 

13.  

14. /**

15.  * 使用递归解析给定的任意一个xml文档并且将其内容输出到命令行上

16.  * @author zhanglong

17.  *

18.  */ 

19. public class DomTest3 

20. { 

21.     public static void main(String[] args) throws Exception 

22.     { 

23.         DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 

24.         DocumentBuilder db = dbf.newDocumentBuilder(); 

25.          

26.         Document doc

补充:软件开发 , Java ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,