作者:朱金灿
来源:http://blog.csdn.net/clever101
对于xml文件,目前我的工作只是集中在配置文件和作为简单的信息文件来用,因此我不太喜欢使用msxml这种重量级的xml解析器,特别是使用msxml解析xml涉及到复杂的com类型转换,更是令人感觉繁琐。因此对于简单的xml文件的解析,我更愿意使用开源的TinyXml。
首先介绍一下TinyXml吧。TinyXML是目前非常流行的一款基于DOM模型的XML解析器,简单易用且小巧玲珑,非常适合存储简单数据,配置文件,对象序列化等数据量不是很大的操作,其主页是:http://www.grinninglizard.com/tinyxml/,目前最新版本是2.5.3
版本。
TinyXml网上的教程很多,但是我觉得写得都不怎样(感觉就是看完之后就没学会)。没办法,只得自己整理一篇适合自己的,至于适不适合别人,就见仁见智了。我感觉xml文件本质就是小型的数据库,换个角度来说就是,你对数据库有什么操作你对xml文件就应能实现什么操作。一般而言,对数据库的操作包括以下几种:新建数据库、查询数据库、修改数据库和删除数据库。那么对应xml文件就是新建xml文件、查询xml文件的指定节点的值,修改xml文件中节点的值和删除xml文件中节点的值。
首先我们认识一下xml文件有哪几种形式。下面我列出一些常用的xml文件的形式:
-
example1.xml:
-
<?xmlversion="1.0"?>
-
<Hello>World</Hello>
-
example2.xml:
-
<?xmlversion="1.0"?>
-
<poetry>
-
<verse>
-
Alas
-
GreatWorld
-
Alas(again)
-
</verse>
-
</poetry>
-
example3.xml:
-
<?xmlversion="1.0"?>
-
<shapes>
-
<circlename="int-based"x="20"y="30"r="50"/>
-
<pointname="float-based"x="3.5"y="52.1"/>
-
</shapes>
-
example4.xml:
-
<?xmlversion="1.0"?>
-
<MyApp>
-
<Messages>
-
<Welcome>WelcometoMyApp</Welcome>
-
<Farewell>ThankyouforusingMyApp</Farewell>
-
</Messages>
-
<Windows>
-
<Windowname="MainFrame"x="5"y="15"w="400"h="250"/>
-
</Windows>
-
<Connectionip="192.168.0.1"timeout="123.456000"/>
-
</MyApp>
上面的例子摘自《TinyXML Tutorial 中文指南》。上面有四个例子,你看到了xml文件的几种表现形式?我看到了本质来说不过是两种表现形式:属性值值在尖括号内,如<Window name="MainFrame" x="5" y="15" w="400" h="250" />和文本在尖括号外,如<Welcome>Welcome to MyApp</Welcome>,具体如下图:
鉴于example4.xml比较复杂,下面我将以此为例介绍tinyxml的使用。
Tinyxml使用了两种编译选择:使用标准C的char *类型或者使用STL中的std::string,其中使用预处理器TIXML_USE_STL进行控制,即添加了TIXML_USE_STL为使用std::string的。鉴于STL的广泛使用以及其强大功能,下面我以使用std::string的tinyxml说明。
首先使用VS 2005打开tinyxmlSTL.dsp的工程文件,将其编译成一个静态库,debug版本为:tinyxmld_STL.lib,然后开始测试tinyxml库。我的测试计划是这样的:首先使用tinyxml库创建example4.xml,然后将其读出来,然后查询指定节点的属性或文本,再修改example4.xml(修改其中的一些节点值和删除其中一个节点,增加一个节点),然后再读出来以判断是否修改成功。具体是在VS 2005上新建一个控制台工程:Test,注意使用多字节字符集进行编译,同时添加。首先是创建xml文件的代码:
-
-
-
-
-
-
-
boolCreateXml(std::stringXmlFile)
-
{
-
-
TiXmlDocument*pDoc=newTiXmlDocument;
-
if(NULL==pDoc)
-
{
-
returnfalse;
-
}
-
TiXmlDeclaration*pDeclaration=newTiXmlDeclaration(_T("1.0"),_T(""),_T(""));
-
if(NULL==pDeclaration)
-
{
-
returnfalse;
-
}
-
pDoc->LinkEndChild(pDeclaration);
-
-
TiXmlElement*pRootEle=newTiXmlElement(_T("MyApp"));
-
if(NULL==pRootEle)
-
{
-
returnfalse;
-
}
-
pDoc->LinkEndChild(pRootEle);
-
-
TiXmlElement*pMsg=newTiXmlElement(_T("Messages"));
-
if(NULL==pMsg)
-
{
-
returnfalse;
-
}
-
pRootEle->LinkEndChild(pMsg);
-
-
TiXmlElement*pWelcome=newTiXmlElement(_T("Welcome"));
-
if(NULL==pWelcome)
-
{
-
returnfalse;
-
}
-
pMsg->LinkEndChild(pWelcome);
-
-
std::stringstrValue=_T("WelcometoMyApp");
-
TiXmlText*pWelcomeValue=newTiXmlText(strValue);
-
pWelcome->LinkEndChild(pWelcomeValue);
-
-
TiXmlElement*pFarewell=newTiXmlElement(_T("Farewell"));
-
if(NULL==pFarewell)
-
{
-
returnfalse;
-
}
-
pMsg->LinkEndChild(pFarewell);
-
-
strValue=_T("ThankyouforusingMyApp");
-
TiXmlText*pFarewellValue=newTiXmlText(strValue);
-
pFarewell->LinkEndChild(pFarewellValue);
-
-
TiXmlElement*pWindows=newTiXmlElement(_T("Windows"));
-
if(NULL==pWindows)
-
{
-
returnfalse;
-
}
-
pRootEle->LinkEndChild(pWindows);
-
-
TiXmlElement*pWindow=newTiXmlElement(_T("Window"));
-
if(NULL==pWindow)
-
{
-
returnfalse;
-
}
-
pWindows->LinkEndChild(pWindow);
-
-
pWindow->SetAttribute(_T("name"),_T("MainFrame"));
-
pWindow->SetAttribute(_T("x"),_T("5"));
-
pWindow->SetAttribute(_T("y"),_T("15"));
-
pWindow->SetAttribute(_T("w"),_T("400"));
-
pWindow->SetAttribute(_T("h"),_T("250"));
-
-
TiXmlElement*pConnection=newTiXmlElement(_T("Connection"));
-
if(NULL==pConnection)
-
{
-
returnfalse;
-
}
-
pRootEle->LinkEndChild(pConnection);
-
-
pConnection->SetAttribute(_T("ip"),_T("192.168.0.1"));
-
pConnection->SetAttribute(_T("timeout"),_T("123.456000"));
-
pDoc->SaveFile(XmlFile);
-
returntrue;
-
}
不知你注意到上面的规律没有?首先父节点连接字节点使用函数LinkEndChild,使用方法是:pParentNode-> LinkEndChild(pChild);其次设置类似这种结构<Window name="MainFrame" x="5" y="15" w="400" h="250" />采用SetAttribute函数,这个函数有两个参数,前一个参数表示键,后一个参数表示键值,设置<Farewell>Thank you for
using MyApp</Farewell>这种结构采用TiXmlText类,使用LinkEndChild函数进行连结。
上面是创建xml文件的代码,下面介绍读取xml文件的代码。打印整个xml文件的代码很简单,代码如下:
-
-
-
-
-
-
-
boolPaintXml(std::stringXmlFile)
-
{
-
-
TiXmlDocument*pDoc=newTiXmlDocument();
-
if(NULL==pDoc)
-
{
-
returnfalse;
-
}
-
pDoc->LoadFile(XmlFile);
-
pDoc->Print();
-
returntrue;
-
}
下次介绍使用tinyxml库对xml文件进行查询指定节点、删除指定节点、修改指定节点和增加节点的用法。
参考文献:
1.《TinyXML入门教程》
2. 《tinyxml 使用笔记与总结》
3. 《TinyXML Tutorial 中文指南》
分享到:
相关推荐
在`TinyXml入门.docx`文档中,可能详细介绍了TinyXML的基本概念、使用方法以及一些常见的应用实例。通过阅读这份文档,你可以系统地学习TinyXML的各个方面,包括创建XML元素、添加属性、遍历元素树、读写XML文件等。...
`TinyXML入门教程.rar`可能包含了一系列示例程序,这些示例展示了如何使用TinyXML进行XML文档的加载、遍历、修改和保存。例如,如何创建一个新的XML文档,添加元素和属性,以及如何从已有的XML文件中提取数据。 4....
TinyXML被设计得容易快速上手。它只有两个头文件和四个cpp文件。只需要把它们简单地加到你的项目中就行了。有一个例子文件——xmltest.cpp来引导你该怎么做。 TinyXML以Zlib许可来发布,所以你可以在开源或者商业...
TinyXML2是一个小型、快速且易于使用的XML解析库,它为C++程序员提供了处理XML文档的能力。这个资源包包括了2015年9月23日从官方网站获取的tinyxml2源码、作者编写的示例代码以及相关介绍文档。由于官方的示例和文档...
在实际应用中,TinyXML适用于小型项目或学习XML解析的入门级工具。然而,对于大型项目或对性能有高要求的场景,可能需要更强大的库,如pugixml、Xerces-C++或 RapidXML,它们提供了更高效和功能丰富的XML处理能力。 ...
1. **TinyXML**: TinyXML是一个小型、开源的C++库,用于解析XML文档。它可以解析XML文件,并将内容转化为DOM(Document Object Model)树,方便遍历和操作。 2. **pugixml**: pugixml是一个轻量级、快速的XML解析器...
可能使用了C++的STL库,或者第三方库如TinyXML、pugixml等来处理XML解析。这个源文件中的代码会读取XML文件,转换其内容并可能以树形结构、对象或数组的形式保存在内存中,方便进一步的处理和分析。 2. **....
在“挑战30天C-C++入门极限系列教程”中,管宁导师旨在为初学者提供一条快速且高效的学习路径,以在短短一个月内掌握C和C++的基础知识。这个系列教程涵盖了C语言和C++语言的核心概念,帮助学员建立起坚实的编程基础...
4. **依赖项(DEPS)**:`CEGUI-DEPS-0.6.0-vc9.zip` 提供了CEGUI运行和构建所需的依赖库,如FreeType用于字体渲染,TinyXML用于解析XML配置文件,以及可能包含的其他库,这些都对CEGUI的正确运行至关重要。...
3. **《starting-struts2-chinese》**:作为入门级别的教材,这本书可能侧重于基础知识,从安装环境、搭建第一个Struts2项目开始,逐步引导读者了解Struts2的基本架构和工作流程。书中可能详细解释了Struts2的生命...