MsXml创建和解析XML示例
一.MsXml创建XML文档示例
// XmlCreationDemo.cpp #include <stdlib.h>
#include <stdio.h> // 引入MSXML解析器
#import <msxml4.dll>
using namespace MSXML2; class InitializeCom
{
public:
InitializeCom() { CoInitialize(NULL); }
~InitializeCom() { CoUninitialize(); }
}InitCom; int main()
{
char *szXmlFile = "D://china.xml"; // xml文件
MSXML2::IXMLDOMDocumentPtr pDoc = NULL; // xml文档
MSXML2::IXMLDOMProcessingInstructionPtr pProInstruction = NULL; // xml声明
MSXML2::IXMLDOMCommentPtr pComment = NULL; // 注释
MSXML2::IXMLDOMElementPtr pRootElement = NULL, pElement = NULL; // 根节点(元素)
MSXML2::IXMLDOMNodePtr pNode = NULL, pNode1 = NULL, pNode2 = NULL; // 节点
MSXML2::IXMLDOMAttributePtr pAttrNode = NULL; // 属性 HRESULT hr = pDoc.CreateInstance(__uuidof(MSXML2::DOMDocument40)); //
if (FAILED(hr))
{
printf("无法创建DOMDocument40对象,请检查是否安装并初始化了MsXml Parser库!");
return EXIT_FAILURE;
} // (1)创建xml文档声明(或insertBefore根节点)
pProInstruction = pDoc->createProcessingInstruction((_bstr_t)(char*)"xml", (_bstr_t)(char*)"version=\"1.0\" encoding=\"utf-8\"");
pDoc->appendChild((MSXML2::IXMLDOMNode*)pProInstruction); // (2)创建根节点<China>
pRootElement = pDoc->createElement((_bstr_t)(char*)"China");
pDoc->PutRefdocumentElement(pRootElement); // pXMLDomDoc->documentElement = pRootElement; // (3)创建节点<China><Continent>
pComment = pDoc->createComment((_bstr_t)(char*)"所在的洲");
pRootElement->appendChild((MSXML2::IXMLDOMNode*)pComment); // 注释 pNode = pDoc->createNode((_variant_t)(long)MSXML2::NODE_ELEMENT, (_bstr_t)(char*)"Continent", (_bstr_t)(char*)"");
pNode->Puttext((_bstr_t)(char*)"Asia"); // pNode->text = "Asia";
pRootElement->appendChild(pNode); // 节点 // (4)创建节点<China><Population>
pComment = pDoc->createComment((_bstr_t)(char*)"人口数量");
pRootElement->appendChild((MSXML2::IXMLDOMNode*)pComment); // 注释 pElement = pDoc->createElement((_bstr_t)(char*)"Population");
pAttrNode = pDoc->createAttribute((_bstr_t)(char*)"Units");
pAttrNode->Puttext((_bstr_t)(char*)"Million Person");
pElement->setAttributeNode(pAttrNode); // 统计单位
pElement->setAttribute((_bstr_t)(char*)"StatisticalYear", (_variant_t)(char*)"2000"); // 统计年份
pElement->Puttext((_bstr_t)(char*)"1,296");
pRootElement->appendChild(pElement); // 节点 // (5)创建节点<China><Municipality>
pComment = pDoc->createComment((_bstr_t)(char*)"四个直辖市");
pRootElement->appendChild((MSXML2::IXMLDOMNode*)pComment); // 注释 pNode = pDoc->createNode((_variant_t)(long)MSXML2::NODE_ELEMENT, (_bstr_t)(char*)"Municipality", (_bstr_t)(char*)"");
pRootElement->appendChild(pNode); // 节点 // (6)创建节点<China><Municipality><TianJin>
pNode1 = pDoc->createNode((_variant_t)(long)MSXML2::NODE_ELEMENT, (_bstr_t)(char*)"TianJin", (_bstr_t)(char*)""); // 创建节点<China><Municipality><TianJin><Area>
pElement = pDoc->createElement((_bstr_t)(char*)"Area");
pElement->setAttribute((_bstr_t)(char*)"Units", (_variant_t)(char*)"Thousand Square kilometers"); // 统计单位
pElement->Puttext((_bstr_t)(char*)"12");
pNode1->appendChild((MSXML2::IXMLDOMNode*)pElement); // 节点 // 创建节点<China><Municipality><TianJin><Population>
pElement = pDoc->createElement((_bstr_t)(char*)"Population");
pElement->setAttribute((_bstr_t)(char*)"Units", (_variant_t)(char*)"Million Person"); // 统计单位
pElement->setAttribute((_bstr_t)(char*)"StatisticalYear", (_variant_t)(char*)"2000"); // 统计年份
pElement->Puttext((_bstr_t)(char*)"10.01");
pNode1->appendChild((MSXML2::IXMLDOMNode*)pElement); // 节点 pNode->appendChild(pNode1);
// (7)创建节点<China><Municipality><BeiJing>并插入<TianJin>前
pNode2 = pDoc->createNode((_variant_t)(long)MSXML2::NODE_ELEMENT, (_bstr_t)(char*)"BeiJing", (_bstr_t)(char*)""); // 创建节点<China><Municipality><BeiJing><Area>
pElement = pDoc->createElement((_bstr_t)(char*)"Area");
pElement->setAttribute((_bstr_t)(char*)"Units", (_variant_t)(char*)"Thousand Square kilometers"); // 统计单位
pElement->Puttext((_bstr_t)(char*)"17");
pNode2->appendChild((MSXML2::IXMLDOMNode*)pElement); // 节点 // 创建节点<China><Municipality><BeiJing><Population>
pElement = pDoc->createElement((_bstr_t)(char*)"Population");
pElement->setAttribute((_bstr_t)(char*)"Units", (_variant_t)(char*)"Million Person"); // 统计单位
pElement->setAttribute((_bstr_t)(char*)"StatisticalYear", (_variant_t)(char*)"2000"); // 统计年份
pElement->Puttext((_bstr_t)(char*)"13.82");
pNode2->appendChild((MSXML2::IXMLDOMNode*)pElement); // 节点 pNode->insertBefore(pNode2, (_variant_t)(IDispatch*)pNode1);
//
// (8)创建节点<China><Municipality><ShangHai>
// (9)创建节点<China><Municipality><ChongQing> pDoc->save((_variant_t)szXmlFile); return EXIT_SUCCESS;
}
生成的china.xml文档内容:
<?xml version="1.0" encoding="utf-8"?>
<China>
<!--所在的洲-->
<Continent>Asia</Continent>
<!--人口数量-->
<Population Units="Million Person" StatisticalYear="2000">1,296</Population>
<!--四个直辖市-->
<Municipality>
<BeiJing>
<Area Units="Thousand Square kilometers">17</Area>
<Population Units="Million Person" StatisticalYear="2000">13.82</Population>
</BeiJing>
<TianJin>
<Area Units="Thousand Square kilometers">12</Area>
<Population Units="Million Person" StatisticalYear="2000">10.01</Population>
</TianJin>
<ShangHai>
<Area Units="Thousand Square kilometers">6.4</Area>
<Population Units="Million Person" StatisticalYear="2000">16.74</Population>
</ShangHai>
<ChongQing>
<Area Units="Thousand Square kilometers">84</Area>
<Population Units="Million Person" StatisticalYear="2000">30.90</Population>
</ChongQing>
</Municipality>
</China>
二.MsXml解析XML文档示例
// XmlParsingDemo.cpp #include <stdlib.h>
#include <stdio.h> // 引入MSXML解析器
#import <msxml4.dll>
using namespace MSXML2; class InitializeCom
{
public:
InitializeCom() { CoInitialize(NULL); // Initializes the COM library }
~InitializeCom() { CoUninitialize(); // Closes the COM library }
}InitCom; int main()
{
char *szXmlFile = "D://china.xml"; //上篇创建的xml文档
IXMLDOMDocumentPtr pDoc = NULL; // xml文档
IXMLDOMNodeListPtr pNodeList = NULL; // 节点链表
IXMLDOMElementPtr pRootElement = NULL, pElement = NULL; // 根节点(元素)
IXMLDOMNodePtr pNode = NULL, pNode1 = NULL; // 节点
IXMLDOMNamedNodeMapPtr pAttrList = NULL; // 属性链表
IXMLDOMAttributePtr pAttrNode = NULL; // 属性
long lChilds, lAttr, i; HRESULT hr = pDoc.CreateInstance(__uuidof(DOMDocument40));
if (FAILED(hr))
{
printf("无法创建DOMDocument40对象,请检查是否安装并初始化了MsXml Parser库!");
return EXIT_FAILURE;
} VARIANT_BOOL bXmlLoad = pDoc->load((_variant_t)szXmlFile);
if (!bXmlLoad) // 加载失败
{
printf("加载%s失败!/n", szXmlFile);
return EXIT_FAILURE;
} // (1)根节点
pRootElement = pDoc->GetdocumentElement();
printf("root = %s/n", (char*)pRootElement->GetnodeName()); // pRootElement->nodeName // (2)根节点的一级子节点
pNodeList = pRootElement->GetchildNodes(); // pRootElement->childNodes
lChilds = pNodeList->Getlength(); // pNodeList->length
for (i = 0; i < lChilds; i++)
{
pNode = pNodeList->Getitem(i); // pNodeList->item[i]
if (pNode->GetnodeType() != NODE_COMMENT) // 过滤注释节点
{
printf("child[%d] of [%s]: [%s]/n", i ,(char*)pRootElement->GetnodeName(), (char*)pNode->GetnodeName());
}
} // (3)统计文档中所有的<Population>节点
pNodeList = pDoc->getElementsByTagName((_bstr_t)(char*)"Population");
lChilds = pNodeList->Getlength();
printf("文档中[Population]共有%d个/n", lChilds); // (4)根节点下的<Population>节点
pNode = pRootElement->selectSingleNode((_bstr_t)(char*)"Population");
// 已知根节点为<China>时:pNode = pDoc->selectSingleNode((_bstr_t)(char*)"China//Population");
printf("根节点下的[Population]子节点值为%s/n", (char*)pNode->Gettext());
pAttrList = pNode->Getattributes();
lAttr = pAttrList->Getlength();
for (i = 0; i < lAttr; i++)
{
pAttrNode = pAttrList->Getitem(i);
printf("Attr[%d] of [%s]: %s = %s/n", i, (char*)pNode->GetnodeName(), (char*)pAttrNode->GetnodeName(), (char*)pAttrNode->Gettext());
} // (5)查找节点<Municipality>下的所有子节点
// "//"表示在任意一层寻找Municipality;"//*"查找<Municipality></Municipality>中的所有子节点
pNodeList = pDoc->selectNodes((_bstr_t)(char*)"//Municipality//*"); // 这里可将pDoc换成pRootElement
while (pNode = pNodeList->nextNode())
{
printf("childs of [Municipality]: %s/n", (char*)pNode->GetnodeName());
} // (6)查找节点<Municipality>下的一级子节点
pNode = pRootElement->selectSingleNode((_bstr_t)(char*)"Municipality");
pNodeList = pNode->GetchildNodes();
lChilds = pNodeList->Getlength();
for (i = 0; i < lChilds; i++)
{
pNode1 = pNodeList->Getitem(i); // pNodeList->item[i]
printf("child[%d] of [Municipality]: %s/n", i, (char*)pNode1->GetnodeName());
} // (7)查询父、子、兄、弟节点
pNode = pRootElement->selectSingleNode((_bstr_t)(char*)"//TianJin");
pNode1 = pNode->GetparentNode(); // 父节点
printf("[TianJin]的父节点为[%s]/n", (char*)pNode1->GetnodeName()); pNodeList = pNode->GetchildNodes(); // 子节点
lChilds = pNodeList->Getlength();
for (i = 0; i < lChilds; i++)
{
pNode1 = pNodeList->nextNode();
printf("child[%d] of [TianJin]: %s/n", i, (char*)pNode1->GetnodeName());
} pNode1 = pNode->GetpreviousSibling(); // 兄节点
printf("[TianJin]的兄节点为[%s]/n", (char*)pNode1->GetnodeName()); pNode1 = pNode->GetnextSibling(); // 弟节点
printf("[TianJin]的弟节点为[%s]/n", (char*)pNode1->GetnodeName()); return EXIT_SUCCESS;
}
运行结果如下:
root = China
child[1] of <China>: <Continent>
child[3] of <China>: <Population>
child[5] of <China>: <Municipality>
文档中<Population>共有5个
根节点下的<Population>子节点值为1,296
Attr[0] of <Population>: Units = Million Person
Attr[1] of <Population>: StatisticalYear = 2000
childs of <Municipality>: BeiJing
childs of <Municipality>: Area
childs of <Municipality>: Population
childs of <Municipality>: TianJin
childs of <Municipality>: Area
childs of <Municipality>: Population
childs of <Municipality>: ShangHai
childs of <Municipality>: Area
childs of <Municipality>: Population
childs of <Municipality>: ChongQing
childs of <Municipality>: Area
childs of <Municipality>: Population
child[0] of <Municipality>: BeiJing
child[1] of <Municipality>: TianJin
child[2] of <Municipality>: ShangHai
child[3] of <Municipality>: ChongQing
<TianJin>的父节点为<Municipality>
child[0] of <TianJin>: Area
child[1] of <TianJin>: Population
<TianJin>的兄节点为<BeiJing>
<TianJin>的弟节点为<ShangHai>
MsXml创建和解析XML示例的更多相关文章
- (转)Android 创建与解析XML—— Dom4j方式 .
转:http://blog.csdn.net/ithomer/article/details/7521605 1.Dom4j概述 dom4j is an easy to use, open sourc ...
- 使用dom4j创建和解析xml文件
使用dom4j创建和解析xml文件 在项目开发中,我们经常会遇到xml文件的创建和解析从别人接口得到的xml文件,而我们最常使用的组件是dom4j. 下面我就以代码来讲解一下如何使用dom4j来创建x ...
- 使用dom4j创建和解析xml
之前工作中用到了,相信写java的都会碰到xml,这里写了两个方法,创建和解析xml,废话不多说,直接上代码 package xml; import java.io.File; import java ...
- dom4j创建和解析xml文档
DOM4J解析 特征: 1.JDOM的一种智能分支,它合并了许多超出基本XML文档表示的功能. 2.它使用接口和抽象基本类方法. 3.具有性能优异.灵活性好.功能强大和极端易用的特点. 4.是一个开 ...
- Java 创建过滤器 解析xml文件
今天写了一个过滤器demo,现在是解析actions.xml文件,得到action中的业务规则:不需要导入任何jar包 ActionFilter过滤器类: package accp.com.xh.ut ...
- GDataXMLNode创建和解析XML
GDataXMLNode创建xml: #import <Foundation/Foundation.h> 2 #import "GDataXMLNode.h" 3 4 ...
- iOS 用GDataXMLNode创建和解析XML
原文地址:http://blog.csdn.net/gf771115/article/details/7718403 NSError *error; // NSString *path = [[ ...
- Android DOM解析XML示例程序
DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据的.DOM比较符合人的思维模式,但是其对内存的消耗比较大. activity_main.xml < ...
- PHP创建与解析 XML 1 (36)
一.使用SimpleXML操控XML 要处理XML 文件,有两种传统的处理思路:SAX 和DOM.SAX 基于事件触发机制,对XML 文件进行一次扫描,完成要进行的处理:DOM 则将整个XML 文件构 ...
随机推荐
- a链接的四种状态
四种状态:hover.link.active.visible a:link{color:#fff;} a链接初始化 a:hover{color:yellow;} 把鼠标放上去的状况 a:active{ ...
- MySQL5.6下使用xtrabackup部分备份恢复到MySQL5.7
现有需求:需要备份MySQL5.6环境下的部分表到MySQL5.7环境下并进行恢复 通过xtrabackup 实现部分备份有三种方式: 参考链接:http://blog.csdn.net/zhu197 ...
- MATLAB中白噪声的产生
rand产生的是[0,1]上的均匀分布的随机序列randn产生均值为0,方差为1的高斯随机序列,也就是白噪声序列 rand产生的是均匀分布白噪声序列randn产生的是正态分布的白噪声序列 MATLAB ...
- .net core 学习笔记(4)-ViewComponent
动态菜单,以前用的是Html.Action(url)来获取的,到了 .net core 中忽然发现没有了这个方法,原来在 .net core 中是提供了个 ViewComponent,有点类似以前的用 ...
- Unable to run app in Simulator
xcode6 beta出现 “Unable to run app in Simulator” 错误提示,之前一直用着好好的,重启xcode就可以了. xcode6 beta出现 “Unable to ...
- Ubuntu 下使用declare的问题
Ubuntu在shell的执行上用户root和普通用户是不一样的. 使用vi /etc/passwd 我们就可以看到在用户的最后一行也就是定义shell执行位置的地方root的位置是/bin/bash ...
- SE1-soc入手又有的东西可以玩了
笔者之前只有DE2-35 和DE2-70 两个板子用,相比之下亮点主要是:配备了DDR3 的存储器,视频处理能处理更高帧频和画幅数了,此外直接有了USB2.0接口,还配有A9 Arm双核芯片,功能一下 ...
- BZOJ 2743 树状数组
不能用分块. #include <bits/stdc++.h> using namespace std; ; struct Info{int l,r,Id;}Q[Maxn]; int a[ ...
- Android下使用Properties文件保存程序设置
原文:http://jerrysun.blog.51cto.com/745955/804789 废话不说,直接上代码. 读取.properties文件中的配置: String strValue ...
- 浅谈FTP 与 LFTP 的 nlist 和 mget 功能
最近因为业务需要,与第三方数据厂商做数据对接,接口方式协定为 FTP传输 ,说说我过程中的dan teng 经历. 开始准备用 lftp mirror 的方式镜像的方式同步数据,由于对方提供的日志文件 ...