一.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示例的更多相关文章

  1. (转)Android 创建与解析XML—— Dom4j方式 .

    转:http://blog.csdn.net/ithomer/article/details/7521605 1.Dom4j概述 dom4j is an easy to use, open sourc ...

  2. 使用dom4j创建和解析xml文件

    使用dom4j创建和解析xml文件 在项目开发中,我们经常会遇到xml文件的创建和解析从别人接口得到的xml文件,而我们最常使用的组件是dom4j. 下面我就以代码来讲解一下如何使用dom4j来创建x ...

  3. 使用dom4j创建和解析xml

    之前工作中用到了,相信写java的都会碰到xml,这里写了两个方法,创建和解析xml,废话不多说,直接上代码 package xml; import java.io.File; import java ...

  4. dom4j创建和解析xml文档

    DOM4J解析  特征: 1.JDOM的一种智能分支,它合并了许多超出基本XML文档表示的功能. 2.它使用接口和抽象基本类方法. 3.具有性能优异.灵活性好.功能强大和极端易用的特点. 4.是一个开 ...

  5. Java 创建过滤器 解析xml文件

    今天写了一个过滤器demo,现在是解析actions.xml文件,得到action中的业务规则:不需要导入任何jar包 ActionFilter过滤器类: package accp.com.xh.ut ...

  6. GDataXMLNode创建和解析XML

    GDataXMLNode创建xml: #import <Foundation/Foundation.h> 2 #import "GDataXMLNode.h" 3 4 ...

  7. iOS 用GDataXMLNode创建和解析XML

    原文地址:http://blog.csdn.net/gf771115/article/details/7718403 NSError *error; //    NSString *path = [[ ...

  8. Android DOM解析XML示例程序

    DOM方式解析xml是先把xml文档都读到内存中,然后再用DOM API来访问树形结构,并获取数据的.DOM比较符合人的思维模式,但是其对内存的消耗比较大. activity_main.xml < ...

  9. PHP创建与解析 XML 1 (36)

    一.使用SimpleXML操控XML 要处理XML 文件,有两种传统的处理思路:SAX 和DOM.SAX 基于事件触发机制,对XML 文件进行一次扫描,完成要进行的处理:DOM 则将整个XML 文件构 ...

随机推荐

  1. 如果Python中有很多换行,可以选择使用"""..."""表示多行内容

    举例:>>> print("""... ... ... ... ... ... ... ... ''')... fdfd""&quo ...

  2. LINUX二十个基础命令

    LINUX二十个基础命令 一. useradd命令 1.命令格式: useradd 选项 用户名 2.命令功能: 添加新的用户账号 3.常用参数: -c comment 指定一段注释性描述.-d 目录 ...

  3. WebGL如何解决中文文字载入

    关于WebGL载入中文字体问题,我在网上搜了一下,发现例子并不多,而且只能实现隶书的载入,不支持其他中文字体. 下面是实现的代码: <script src="../js/three.m ...

  4. 关于最少VC号数目的猜想

    [事先说明,实际的虚拟电路的实际物理链路可能同时具有多个VC号,但每段逻辑链路仅有一个VC号,一条完整虚拟路径由多个段组成] 问题描述: 在一个虚拟电路交换网络中,每个路由器的直连链路都有一个独一无二 ...

  5. C++线程中packaged_tack

    packaged_tack<>函数是一个你可以先定义好任务的类型,但是不想马上启动.函数可以在你想要启动任务是启动,你只需要调用你声明的函数就可以. #include <future ...

  6. Log4j简介

    Log4J日志配置详解   一.Log4j简介Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和 ...

  7. 搭建java web开发环境、使用eclipse编写第一个java web程序

    开发工具:eclipse-jee-juno-SR2-win32-x86_64(请自行官网下载) 使用服务器:apache-tomcat-7.0.35-windows-x64(请自行官网下载) 打开 e ...

  8. Docker简明教程

    Docker简明教程 [编者的话]使用Docker来写代码更高效并能有效提升自己的技能.Docker能打包你的开发环境,消除包的依赖冲突,并通过集装箱式的应用来减少开发时间和学习时间. Docker作 ...

  9. 输入两个正整数m和n,求其最大公约数和最小公倍数

    public static void main(String[] args){  Scanner sc = new Scanner (System.in);  int a,b;  System.out ...

  10. Unity使用protobuf-net进行二进制序列化与反序列化

    Protobuf-net提供的一种易于使用的数据序列化方案,可序列化带有[ProtoContract]特性的类实例,并可支持Unity各个发布平台,且效率高.易用性强. public static c ...