XML技术系列讲座(八)

8.       通过DOM操作数据(下)

1、DOM解析时的错误

 

DOM在解析XML文档的时候可能会产生各式各样的错误,可以根据ParseError对象中的属性得知出错的可能原因及相关信息。

 

常用的属性及其含义如下表所示:

 

属性

说明

errorCode

错误代码

filepos

错误在文档中的绝对字符位置

line

错误所在行的行号

linepos

错误所在行的字符位置

reason

错误产生原因

srcText

错误所在行的源代码

url

最近一份含有解析错误的XML文档的URL地址

 

 

2、访问DOM树中的元素与属性

 

DOM还提供了许多查找节点的方法。其中基于搜索机制的方法有:

 

根据标签名称搜索元素;

 

使用XSL模式搜索节点;

 

利用集合索引搜索节点。

 

books.xml为例,Document对象中的getElementsByTagName方法就是根据参数中的标签名称在全文范围内查找元素的,返回值是一个NodeList对象:

 

Set doc = dsoDetails.XMLDocument

 

Set authors = doc.getElementsByTagName(“author”)

 

上述查询结果中包含了文档中出现的全部4位作者。如果调用的是Element对象中的getElementsByTagName方法,除了搜索范围缩小为该元素的所有后继节点之外,其他的情况都是一样的。

 

所有类型的节点都带有selectNodes方法,该方法的唯一参数是XSL的模式规则,返回值是匹配该规则的结果集合。调用这个方法可以利用XSL的模式匹配策略查找节点。例如:

 

Set rootNode = doc.documentElement

 

Set cheapbooks = rootNode.selectNodes(“//book[price < 10]”)

 

这个例子返回所有售价低于10元的<book>元素。另外,节点中的selectSingleNodes方法的用法与selectNodes是一样的,只是返回结果为查找到的满足条件的第一个节点而已。

 

对于元素节点,获取元素标签名称的方法有两种:anyElement.nodeNameanyElement.tagName。前者是Node对象的属性,后者是Element对象的属性。

 

如果想获取元素中的文本内容,如: <price>9.95

 

</price>时,访问Element对象中的nodeValue属性是错误的,这时返回结果是null,而不是预期的9.95。含有文本内容的元素都包含一个Text类型的子节点,所以只有通过Text对象中的nodeValue属性才能真正访问到文本内容。

 

添加元素的步骤如下:

 

创建一个Text节点并赋值;

 

创建Element节点;

 

Text节点挂在Element节点下,作为它的子节点;

 

Element节点插入到XML文档的合适位置上。

 

对于元素节点的删除和替换操作,首先都要对操作对象进行定位,然后相应地执行对象节点所属父节点的removeChild方法和replaceChild方法即可。

 

Attr节点的各种操作在原理上与Element节点相同。Attr对象同样继承了Node对象中的各种方法和属性,并且MSXML中还提供了name属性和value属性,能够更直接地访问到属性信息。另外,还可以通过属性所属元素的相关方法访问属性,如通过getAttributesetAttribute方法读取属性值或修改属性值,或者用getAttributeNode方法直接返回Attr对象。

 

创建新属性最直接的办法就是使用Element对象中的setAttribute方法。也可以先用Document对象中的createAttribute方法设置属性值,然后使用Element对象中的setAttributeNode方法把新节点添加到DOM树中。同样地,删除属性最直接的方法是调用Element中的removeAttribute方法。另外一种方案是先用getAttributeNode方法对操作对象进行定位,然后执行removeAttributeNode操作。

 

从以上的介绍中可以看出,由于节点间的继承关系,以及各种类型节点本身提供的丰富的接口,用户可以很容易地找到一套适合自己需要的对象操作方案。

 

 

3、DOM的显示功能

 

DOM技术还可以用来显示XML数据。XSL样式单面向的是XML文档的转换,用于显示格式的转换是其应用的一个方面,所以在显示功能上还存在着一些不足:

 

不易完成对XML数据的复杂处理,如将英文字母全部转换为大写,截取指定长度的字符串,忽略一些特定的标点等;

 

不易对XML数据中的数值进行计算;

 

一个XSL通常是静态地作用到一个XML文档上,无法将多个XML文档中的数据用一个XSL合并转换为一个输出结果。

 

使用DOM就能够很好地解决上述问题,而且编写的脚本在服务器端和客户端都能够执行。在客户端可以根据情况创建友好的用户界面与用户进行交互,在服务器端使用脚本利用DOM可以按客户端的需求将数据进行组织并且发送。

 

下面的这个例子就是把XML文档转换成HTML中的表格:

 

Dim outstr

 

outstr = “<TABLE BORDER=1>”

 

Set listOrderitem = doc.selectNodes(“//orderitem”)

 

For Each node In listOrderitem

 

outstr = outstr & “<TR>” & _

 

“<TD>” & node.getAttribute(“title”) & _

 

“</TD>” & _

 

“<TD>” & node.getAttribute(“isbn”) & _

 

“</TD></TR>”

 

Next

 

outstr = outstr & “</TABLE>”

 

下面的这个例子则是对XML数据进行数值运算,计算书本的平均售价:

 

totalPrice = 0

 

Set listPrice = doc.selectNodes(“//price”)

 

For Each node In listPrice

 

totalPrice = totalPrice + node.firstChild.nodeValue

 

Next

 

avgPrice = totalPrice / listPrice.length

 

最后的这个例子显示了DOM 把多个XML文档合并转换显示的强大功能:

 

<XML ID=“dsoOrders” src=“Orders.xml”></XML>

 

<XML ID=“dsoCustomers” src=“Customers.xml”></XML>

 

Set docOrders = dsoOrders.XMLDocument

 

Set docCustomers = dsoCustomers.XMLDocument

 

outstr = “<P>Number of order items: ” & _

 

docOrders.selectNodes(“//orderitem”).length & _

 

“<P>Number of customers: ” & _

 

docCustomers.selectNodes(“//customer”).length

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值