<?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 个项。
XML之DOM解析模型
时间: 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