XML之DOM解析模型

<?xml version= "1.0" encoding = "UTF-8">
<articles>
      <article category="xml">
             <title>XML概述</title>
             <author>Jerry</author>
             <email>[email protected]</email>
             <date>2014-10-20</date>
      </article>
</articles>

DOM解析(DocumentObject Mode)是一种基于对象的API,它把XML的内容加载到内存中,生成一个与XML文档内容对应的对象模型。当解析完成后,内存中会生成一个对应的DOM树

XML解析只负责解析正确的XML,而不负责判断XML是否合法,如果不合法,会直接抛出解析异常

import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class DomParser{

public static void main(String [] args){
      File xmlFile = new ("E:\\article.xml");
      DocumentBuilder builder = null;
      DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
      try{
             builder = builderFactory.newDocumentBuilder();
             Document document = builder.parse(xmlFile);
             Element root = document.getDocumentElement();
             System.out.println("根元素:"+root.getNodeName());
             NodeList childNodes = root.getChildNodes();
             for(int i =0;i<childNodes.getLength();i++){
                    Node node =childNodes.item(i);
                    if(“article”.equals(node.getNodeName())){
                           System.out.println("文章所属分类:"+node.getAttributes().getNamedItem("category").getNodeValue());
                           NodeListnodeDetail = node.getChildNodes();
                           for(intj=0;j< nodeDetail.getLength();j++){
                                  Nodedetail = nodeDetail.item(j);
                                  if("title".equals(detail.getNodeName()))
                                  System.out.println("标题:"+detail.getTextContenet());
                                  elseif("author".equals(detail.getNodeName()))
                                  System.out.println("作者:"+detail.getTextContenet());
                                  elseif("email".equals(detail.getNodeName()))
                                  System.out.println("电子邮件:"+detail.getTextContenet());
                                  elseif("date".equals(detail.getNodeName()))
                                  System.out.println("日期:"+detail.getTextContenet());
                           }
                    }
             }
      }catch(Exception e){
             e.printStackTrace();
      }
}
}

Node对象

Node     appendChild(Node newChild)

将节点 newChild 添加到此节点的子节点列表的末尾。

Node   cloneNode(booleandeep)

返回此节点的副本,即允当节点的一般复制构造方法。

short   compareDocumentPosition(Nodeother)

就节点在文档中的位置并按照文档的顺序,比较引用节点(即在其上调用此方法的节点)与作为参数传递的节点。

NamedNodeMap    getAttributes()

包含此节点的属性的NamedNodeMap(如果它是 Element);否则为 null。

String  getBaseURI()

此节点的绝对基 URI;如果实现不能获得绝对URI,则为 null。

NodeList    getChildNodes()

包含此节点的所有子节点的 NodeList。

Object       getFeature(Stringfeature, String version)

此方法返回一个特定的对象,该对象实现指定功能或版本的特定 API,如下所述。

Node   getFirstChild()

此节点的第一个子节点。

Node   getLastChild()

此节点的最后一个节点。

String  getLocalName()

返回此节点限定名称的本地部分。

String  getNamespaceURI()

此节点的名称空间 URI;如果它未被指定,则返回null(参见)。

Node   getNextSibling()

直接在此节点之后的节点。

String  getNodeName()

此节点的名称,取决于其类型;参见上表。

short   getNodeType()

表示基础对象的类型的节点,如上所述。

String  getNodeValue()

此节点的值,取决于其类型;参见上表。

Document getOwnerDocument()

与此节点相关的 Document 对象。

Node   getParentNode()

此节点的父节点。

String  getPrefix()

此节点的名称空间前缀;如果它未被指定,则为null。

Node   getPreviousSibling()

直接在此节点之前的节点。

String  getTextContent()

此属性返回此节点及其后代的文本内容。

Object       getUserData(Stringkey)

检索与此节点上的某个键相关联的对象。

boolean     hasAttributes()

返回此节点(如果它是一个元素)是否具有任何属性。

boolean     hasChildNodes()

返回此节点是否具有任何子节点。

Node   insertBefore(NodenewChild, Node refChild)

在现有子节点 refChild 之前插入节点newChild。

boolean     isDefaultNamespace(StringnamespaceURI)

此方法检查指定的 namespaceURI是否是默认名称空间。

boolean     isEqualNode(Nodearg)

测试两个节点是否相等。

boolean     isSameNode(Nodeother)

返回此节点是否是与给定节点相同的节点。

boolean     isSupported(Stringfeature, String version)

测试 DOM 实现是否实现特定功能,且该功能是否受此节点支持,如下所述。

String  lookupNamespaceURI(Stringprefix)

从此节点开始,查找与给定前缀相关的名称空间URI。

String  lookupPrefix(StringnamespaceURI)

从此节点开始,查找与给定名称空间 URI 相关的前缀。

void    normalize()

将此 Node 之下完整的深层子树中所有Text 节点(包括属性节点)放入只有结构(如元素、注释、处理指令、CDATA 节和实体引用)分隔 Text 节点的“常规”形式,也就是说,既没有相邻的 Text 节点,也没有空 Text 节点。

Node   removeChild(NodeoldChild)

从子节点列表中移除 oldChild 所指示的子节点,并将其返回。

Node   replaceChild(NodenewChild, Node oldChild)

将子节点列表中的子节点 oldChild 替换为 newChild,并返回 oldChild节点。

void    setNodeValue(StringnodeValue)

此节点的值,取决于其类型;参见上表。

void    setPrefix(Stringprefix)

此节点的名称空间前缀;如果未指定,则为null。

void    setTextContent(StringtextContent)

此属性返回此节点及其后代的文本内容。

Object       setUserData(Stringkey, Object data, UserDataHandler handler)

将对象与此节点上的键相关联。

Document对象

Node     adoptNode(Node source)

试图把另一文档中的节点采用到此文档。

Attr     createAttribute(Stringname)

创建给定名称的 Attr。

Attr     createAttributeNS(StringnamespaceURI, String qualifiedName)

创建给定的限定名称和名称空间 URI 的属性。

CDATASection   createCDATASection(Stringdata)

创建其值为指定字符串的CDATASection 节点。

Comment  createComment(Stringdata)

创建给定指定字符串的 Comment 节点。

DocumentFragment       createDocumentFragment()

创建空 DocumentFragment 对象。

Element     createElement(StringtagName)

创建指定类型的元素。

Element     createElementNS(StringnamespaceURI, String qualifiedName)

创建给定的限定名称和名称空间 URI 的元素。

EntityReference      createEntityReference(String name)

创建 EntityReference 对象。

ProcessingInstruction     createProcessingInstruction(String target, String data)

创建给定指定名称和数据字符串的ProcessingInstruction 节点。

Text    createTextNode(Stringdata)

创建给定指定字符串的 Text 节点。

DocumentType getDoctype()

与此文档相关的文档类型声明(参见DocumentType)。

Element     getDocumentElement()

这是一种便捷属性,该属性允许直接访问文档的文档元素的子节点。

String  getDocumentURI()

文档的位置,如果未定义或 Document是使用 DOMImplementation.createDocument 创建的,则为 null。

DOMConfiguration getDomConfig()

调用Document.normalizeDocument() 时使用的配置。

Element     getElementById(StringelementId)

返回具有带给定值的 ID 属性的 Element。

NodeList    getElementsByTagName(Stringtagname)

按文档顺序返回包含在文档中且具有给定标记名称的所有 Element 的 NodeList。

NodeList    getElementsByTagNameNS(StringnamespaceURI, String localName)

以文档顺序返回具有给定本地名称和名称空间URI 的所有 Elements 的 NodeList。

DOMImplementation    getImplementation()

处理此文档的DOMImplementation 对象。

String  getInputEncoding()

指定解析时此文档使用的编码的属性。

boolean     getStrictErrorChecking()

指定是否强制执行错误检查的属性。

String  getXmlEncoding()

作为 XML 声明的一部分,指定此文档编码的属性。

boolean     getXmlStandalone()

作为 XML 声明的一部分,指定此文档是否为独立文档的属性。

String  getXmlVersion()

作为 XML 声明 的一部分指定此文档版本号的属性。

Node   importNode(NodeimportedNode, boolean deep)

从另一文档向此文档导入节点,而不改变或移除原始文档中的源节点;此方法创建源节点的一个新副本。

void    normalizeDocument()

此方法的行为如同使文档通过一个保存和加载的过程,而将其置为 "normal(标准)" 形式。

Node   renameNode(Noden, String namespaceURI, String qualifiedName)

重命名 ELEMENT_NODE 或ATTRIBUTE_NODE 类型的现有节点。

void    setDocumentURI(StringdocumentURI)

文档的位置,如果未定义或 Document是使用 DOMImplementation.createDocument 创建的,则为 null。

void    setStrictErrorChecking(booleanstrictErrorChecking)

指定是否强制执行错误检查的属性。

void    setXmlStandalone(booleanxmlStandalone)

作为 XML 声明 的一部分指定此文档是否是单独的的属性。

void    setXmlVersion(StringxmlVersion)

作为 XML 声明 的一部分指定此文档版本号的属性。

Attr对象

String    getName()

返回此属性的名称。

Element     getOwnerElement()

此属性连接到的 Element 节点;如果未使用此属性,则为 null。

TypeInfo    getSchemaTypeInfo()

与此属性相关联的类型信息。

boolean     getSpecified()

如果在实例文档中显式给此属性一个值,则为True;否则为 false。

String  getValue()

检索时,该属性值以字符串形式返回。

boolean     isId()

返回是否此属性属于类型 ID(即包含其所有者元素的标识符)。

void    setValue(Stringvalue)

检索时,该属性值以字符串形式返回。

DocumentType对象

NamedNodeMap      getEntities()

包含在 DTD 中声明的内部和外部常规实体的 NamedNodeMap。

String  getInternalSubset()

以字符串表示的内部子集,如果没有内部子集,则为 null。

String  getName()

DTD 的名称;即紧跟在 DOCTYPE 关键字后面的名称。

NamedNodeMap    getNotations()

包含在 DTD 中声明的表示法的NamedNodeMap。

String  getPublicId()

外部子集的公共标识符。

String  getSystemId()

外部子集的系统标识符。

Element对象

String    getAttribute(String name)

通过名称获得属性值。

Attr     getAttributeNode(Stringname)

通过名称获得属性节点。

Attr     getAttributeNodeNS(StringnamespaceURI, String localName)

通过本地名称和名称空间 URI 获得 Attr 节点。

String  getAttributeNS(StringnamespaceURI, String localName)

通过本地名称和名称空间 URI 获得属性值。

NodeList    getElementsByTagName(Stringname)

以文档顺序返回具有给定标记名称的所有后代Elements 的 NodeList。

NodeList    getElementsByTagNameNS(StringnamespaceURI, String localName)

以文档顺序返回具有给定本地名称和名称空间URI 的所有后代 Elements 的 NodeList。

TypeInfo    getSchemaTypeInfo()

与此元素相关的类型信息。

String  getTagName()

元素的名称。

boolean     hasAttribute(Stringname)

当具有给定名称的属性在此元素上被指定一个值或具有默认值时,返回 true;否则返回 false。

boolean     hasAttributeNS(StringnamespaceURI, String localName)

当具有给定本地名称和名称空间 URI 的属性在此元素上被指定一个值或具有默认值时,返回 true;否则返回 false。

void    removeAttribute(Stringname)

通过名称移除一个属性。

Attr     removeAttributeNode(AttroldAttr)

移除指定的属性节点。

void    removeAttributeNS(StringnamespaceURI, String localName)

通过本地名称和名称空间 URI 移除属性值。

void    setAttribute(Stringname, String value)

添加一个新属性。

Attr     setAttributeNode(AttrnewAttr)

添加新的属性节点。

Attr     setAttributeNodeNS(AttrnewAttr)

添加新属性。

void    setAttributeNS(StringnamespaceURI, String qualifiedName, String value)

添加新属性。

void    setIdAttribute(Stringname, boolean isId)

如果参数 isId 为 true,则此方法将指定的属性声明为用于确定用户的 ID 属性。

void    setIdAttributeNode(AttridAttr, boolean isId)

如果参数 isId 为 true,则此方法将指定的属性声明为用户确定的 ID 属性。

void    setIdAttributeNS(StringnamespaceURI, String localName, boolean isId)

如果参数 isId 为 true,则此方法将指定的属性声明为用户确定的 ID 属性。

NamedNodeMap对象

int  getLength()

此映射中的节点数。

Node   getNamedItem(Stringname)

检索通过名称指定的节点。

Node   getNamedItemNS(StringnamespaceURI, String localName)

检索通过本地名称和名称空间 URI 指定的节点。

Node   item(intindex)

返回映射中第 index 个项。

Node   removeNamedItem(Stringname)

移除通过名称指定的节点。

Node   removeNamedItemNS(StringnamespaceURI, String localName)

移除通过本地名称和名称空间 URI 指定的节点。

Node   setNamedItem(Nodearg)

使用 nodeName 属性添加节点。

Node   setNamedItemNS(Nodearg)

使用其 namespaceURI 和 localName 添加节点。

NodeList对象

int  getLength()

列表中的节点数。

Node   item(intindex)

返回集合中的第 index 个项。

时间: 2024-12-26 12:01:33

XML之DOM解析模型的相关文章

xml语法、DTD约束xml、Schema约束xml、DOM解析xml

今日大纲 1.什么是xml.xml的作用 2.xml的语法 3.DTD约束xml 4.Schema约束xml 5.DOM解析xml 1.什么是xml.xml的作用 1.1.xml介绍 在前面学习的html语言,html是超文本标记语言,使用html语言规定好的标签来封装文本数据.而html使用的标签html语言规定好的,每个标签都有自己特定的功能. xml语言,可扩展的标记语言,这门语言它没有定义任何的标记,而标记是由使用者自己来定义,但是由于标签名称以及属性名称都由用户自己来命名,导致别人在使

mybatis 解析配置文件(一)之XML的DOM解析方式

简介 在之前的文章<mybatis 初步使用(IDEA的Maven项目, 超详细)>中, 讲解了mybatis的初步使用, 并总结了以下mybatis的执行流程: 通过 Resources 工具类读取 mybatis-config.xml, 存入 Reader: SqlSessionFactoryBuilder使用上一步获得的reader创建SqlSessionFactory对象; 通过 sqlSessionFactory 对象获得SqlSession; SqlSession对象通过selec

利用jaxp对xml进行dom解析

1 <?xml version="1.0" encoding="UTF-8"?> 2 <书架> 3 <书> 4 <书名>何茂赟自传</书名> 5 <作者>何茂赟</作者> 6 <售价>100.00元</售价> 7 </书> 8 <书> 9 <书名>何茂赟自传2</书名> 10 <作者>何茂赟</

XML之DOM解析文档

TestDom.java package com.sxt.dom; import java.io.File; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import org.w3c.dom.Do

使用jaxp对比xml进行DOM解析

/*DOM解析编程 •遍历所有节点 •查找某一个节点 •删除结点 •更新结点 •添加节点 /* package cn.itcast.jaxp; import java.io.File; import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigu

jaxp解析XML之DOM解析

XML解析技术XML解析方式分为三种一种是DOM解析一种是SAX解析 DOM思想:将整个xml加载入内存,形成围挡对象,所有对xml操作都是对内存中节点对象进行,DOM是官方xml解析标准,同时支持解析其他各种语言 SAX解析方式的出现,因为DOM的解析方式需要对文档进行加载入内存,当文档较大的时候比较消耗资源,这时候就出现了SAX解析SAX思想:一边解析,一边处理,一边释放资源 在JDK6中又引入了另一种StAX解析方式是一种拉模式的xml解析方式,而SAX是一种推模式XML解析方式推模式由服

XML(七)-DOM解析

DOM解析 JAXP(Java API for XML Parsing) :用于XML解析的Java API. 本文通过一个实际的代码例子来说明如何用Java提供的DOM相关的类和接口解析XML: 首先,是XML文档:persons.xml <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <!DOCTYPE persons [ <!ENTITY xx &quo

用java操作XML文件(DOM解析方式)

XML 可扩展标记语言(Extensible Markup Language),是独立于软件和硬件的传输工具. XML的作用: (1)用作配置文件 (2)简化数据共享 (3)简化数据传输 XML DOM解析方式 在java工程中导入dom4j.jar包. (一)用java读XML文件 <1>创建SAXReader对象. RAXReader reader=new RAXReader(); <2>调用RAXReader的Document read(File file)方法,获取xml文

XML之SAX解析模型

DOM解析会把整个XML文件全部映射成Document里的树形结构,当遇到比较大的文件时,它的内存占用很大,查找很慢 SAX就是针对这种情况出现的解决方案,SAX解析器会从XML文件的起始位置起进行解析,同时根据已经定义好的事件处理器,来决定当前所解析的部分是否有必要进行记录并存储 import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public c