4.4 使用DOMDocument读写XML
既然XML文件是文本文件,那么当然可以用文本文件读写的方式对XML文件进行存取。微软提供了专门针对XML的对象模型DOM(Document Object Model),可以对XML进行全面操作。
4.4.1 引入DOMDocument对象
前期绑定:在VBA工程中添加引用“Microsoft XML, v 6.0”,如图4-6所示。
图4-6 添加外部引用
添加该外部引用后,代码中使用
Dim Doc As MSXML2.DOMDocument
就声明了一个对象变量。
后期创建DOMDocument对象如下。
Set Doc = CreateObject("MSXML2.DOMDocument")
下面分别讲述把各种来源的XML载入DOMDocument的方法。
4.4.2 装载本地文件
使用DOMDocument对象的Load函数,可以把本地XML文件装载到DOM对象模型中。
语法如下。
Load(xmlSource)
参数xmlSource是指XML文件的路径,如果装载成功,Load函数返回True。
下面的过程装载本地XML文件,并在立即窗口打印文档对象的XML代码。
代码分析:无论是DOMDocument,还是其他的各种节点,几乎都有一个XML属性,该属性返回的是对象的XML代码字符串。因此可以通过调用该属性来查看节点的情况。
4.4.3 装载网络文件
很多情况下,XML文件是网络上的一个远程文件,此时可以使用XMLhttp对象通过URL请求,返回一个responseXML,然后赋给DOMDocument对象即可。
下面的代码从w3school网站上获取一个XML文件,然后装载到程序中的DOMDocument对象中。
运行上述代码,立即窗口打印出XML文件的源代码。
4.4.4 装载字符串
除了使用Load函数装载文件外,还可以使用LoadXML函数直接装载程序中的字符串。
下面的过程把程序中的字符串装载到DOMDocument中。
代码分析:如果变量code中的字符串不符合XML的语法规则,会弹出“你的代码不合法,装载失败!”的警告对话框。
上述过程运行后,立即窗口显示的运行结果如图4-7所示。
注意,创建XML的字符串中,表示元素的属性值时,可以用单引号代替双引号。
图4-7 XML文档装载字符串
4.4.5 保存XML文件
不管是从哪一个来源装载的DOMDocument,随时都可以使用DOMDocument对象的Save方法保存为本地XML文件。用法如下。
DOC.Save "C:\build\temp.xml"
其中DOC就是一个DOMDocument对象,运行上述语句,会在指定路径下生成一个XML文件。