java xml解析 学习笔记(1)――DOM(一)

2014-11-24 00:35:09 · 作者: · 浏览: 0

本文一简单的例子来介绍xml4种方式解析的方法,以及他们的区别。内容来自网络,笔者只是稍作整理。

首先介绍一下xml

XML文档节点类型

u 文档(document)

u 元素(element)

u 属性(attribute)

u 文本(PCDATA--parsed character data)

u 注释(comment)

u DOCTYPE :主要验证文档内容的正确性

u 实体(ENTITIES)

u CDATA(character data)

XML语法
1、声明:
  
2、根节点:必须有一个根节点
3、标签:标签必须有结束且区分大小写,标签必须顺序嵌套
4、属性:必须引号引起值
5、空格会被保留,HTML空格最多保留一个
6、命名规则:命名必须见名知意

a) 名字可包含字母、数字以及其他的字符

b) 名字不能以数字或者标点符号开始

c) 名字不能以字符“xml”(或者XML、Xml)开始

7、名字不能包含空格 
8、 不应在 XML 元素名称中使用 ":" ,这是由于它用于命名空间(namespaces)的保留字。
9、标签优先于属性。

10、XML 命名空间可提供避免元素命名冲突的方法。

11、CDATA:字符数据,字符数据 ,字符数据不进行转义

12、实体:&实体;

一个简答的xml文件做案例:把他放到src目录下。

first.xml

  

  

    
     
     
       鲁B1234 
      
     
       山东省青岛市 
      
     
     
     
       鲁A1234 
      
     
       山东省济南市 
      
     
   

  

1)DOM(JAXP Crimson解析器)
DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准。DOM是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的。DOM以及广义的基于树的处理具有几个优点。首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构作出更改。它还可以在任何时候在树中上下导航,而不是像SAX那样是一次性的处理。DOM使用起来也要简单得多。

package Test;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
public class MyXmlReader{ 
	 public static void main(String[] args) {
		 try{
			 File f=new File("src/first.xml"); 
			 DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); //1、创建DocumentBuilder工厂 
			 DocumentBuilder builder=factory.newDocumentBuilder(); //2、创建DocumentBuilder  
			 Document doc = builder.parse(f);  //3、将xml文件解析为Document对象,代表DOM树
			 NodeList nl = doc.getElementsByTagName("value"); 
			 for (int i=0;i
  

   

DOM的基本对象有5个:Document,Node,NodeList,Element和Attr。下面一一介绍一下:

1.1、Document对象

代表了整个XML的文档,所有其它的Node,都以一定的顺序包含在Document对象之内,排列成一个树形的结构,程序员可以通过遍历这颗树来得到XML文档的所有的内容,这也是对XML文档操作的起点。我们总是先通过解析XML源文件而得到一个Document对象,然后再来执行后续的操作。此外,Document还包含了创建其它节点的方法,比如createAttribut()用来创建一个Attr对象。它所包含的主要的方法有:

createAttribute(String):用给定的属性名创建一个Attr对象,并可在其后使用setAttributeNode方法来放置在某一个Element对象上面。

createElement(String):用给定的标签名创建一个Element对象,代表XML文档中的一个标签,然后就可以在这个Element对象上添加属性或进行其它的操作。

createTextNode(String):用给定的字符串创建一个Text对象,Text对象代表了标签或者属性中所包含的纯文本字符串。如果在一个标签内没有其它的标签,那么标签内的文本所代表的Text对象是这个Element对象的唯一子对象。

getElementsByTagName(String):返回一个NodeList对象,它包含了所有给定标签名字的标签。

getDocumentElement():返回一个代表这个DOM树的根节点的Element对象,也就是代表XML文档根元素的那个对象。

1.2、Node对象

是DOM结构中最为基本的对象,代表了文档树中的一个抽象的节点。在实际使用的时候,很少会真正的用到Node这个对象,而是用到诸如Element、Attr、Text等Node对象的子对象来操作文档。Node对象为这些对象提供了一个抽象的、公共的根。虽然在Node对象中定义了对其子节点进行存取的方法,但是有一些Node子对象,比如Text对象,它并不存在子节点,这一点是要注意的。Node对象所包含的主要的方法有:

appendChild(org.w3c.dom.Node):为这个节点添加一个子节点,并放在所有子节点的最后,如果这个子节点已经存在,则先把它删掉再添加进去。

getFirstChild():如果节点存在子节点,则返回第一个子节点,对等的,还有getLastChild()方法返回最后一个子节点。

getNextSibling():返回在DOM树中这个节点的下一个兄弟节点,对等的,还有getPreviousSibling()方法返回其前一个兄弟节点。

getNodeName():根据节点的类型返回节点的名称。

getNodeType():返回节点的类型。

getNodeva lue():返回节点的值。

hasChildNodes():判断是不是存在有子节点。

hasAttributes():判断这个节点是否存在有属性。

getOwnerDocument():返回节点所处的Document对象。

insertBefore(org.w3c.dom.Node new,org.w3c.dom.Node ref):在给定的一个子对象前再插入一个子对象。

removeChild(org.w3c.dom.Node):删除给定的子节点对象。

replaceChild(org.w3c.dom.Node new,org.w3c.dom.Node old):用一个新的Node对象代替给定的