C++ XML解析之TinyXML篇

最近使用TinyXML进行C++ XML解析,感觉使用起来比较简单,很容易上手,本文给出一个使用TinyXML进行XML解析的简单例子,很多复杂的应用都可以基于本例子的方法来完成。以后的文章里会讲解使用Xerces进行C++ XML解析的例子,希望大家一起交流。
TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译。这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树。
    DOM模型即文档对象模型,是将整个文档分成多个元素(如书、章、节、段等),并利用树型结构表示这些元素之间的顺序关系以及嵌套包含关系。
    首先从网上下载TinyXML的库,文件夹的名字是TinyXpath,在工程里做如下配置:
    在附加包含路径里添加:你的tinyxpath路径/tinyxpath/include
    在附加库路径里添加:你的tinyxpath路径/tinyxpath/lib
    在对象/库路径里添加:tinyxpathd.lib,如果使用release版本,则是tinyxpath.lib。
    另外,由于我开发的项目是多线程的,所以设置了多线程的环境,因此使用TinyXML没有出现问题。本人将TinyXML写在一个单独的C++工程进行测试,发现如果不设置多线程的环境,会出现链接错误我觉得原因可能是TinyXML使用了多线程环境,因此需要设置
多线程的环境。在工程/设置下的C/C++选项卡中,选择Code Generation,在Use run-time library中选择Debug MultiThreaed DLL即可。
    本例的XML文件Students.xml如下:
    <Students>
            <phone>88208888</phone>
        </student>
            <phone>88206666</phone>
        </student>
</Class>

    程序代码XmlParseExample.cpp如下所示:
#include < string>

  using std:: string;
{
  myDocument->LoadFile( "Students.xml");
  TiXmlElement* studentsElement = rootElement->FirstChildElement();   //Students
   while ( studentElement ) {
     while ( attributeOfStudent ) {
      attributeOfStudent = attributeOfStudent->Next();
    TiXmlElement* phoneElement = studentElement->FirstChildElement(); //获得student的phone元素
    TiXmlElement* addressElement = phoneElement->NextSiblingElement();
    studentElement = studentElement->NextSiblingElement();
   return 0;
string xmlString = 
<img http:="" blog.51cto.com="" viewpic.php?refimg=" + this.src)" src="http://panpan.blog.51cto.com/'#\'"" editer="" inblock.gif"="" align="top" style="padding: 0px; margin: 0px; vertical-align: top; border: none;">            "<Class name=\"计算机软件班\">\
                <student name=\"张三\" studentNo=\"13031001\" sex=\"男\" age=\"22\">\
                  <address>西安市太白南路二号</address>\
                <student name=\"李四\" studentNo=\"13031002\" sex=\"男\" age=\"20\">\
                  <address>西安市光华路</address>\
              </Students>\
<img http:="" blog.51cto.com="" viewpic.php?refimg=" + this.src)" src="http://panpan.blog.51cto.com/'#\'"" editer="" inblock.gif"="" align="top" style="padding: 0px; margin: 0px; vertical-align: top; border: none;">            </Class>";
  myDocument->Parse(xmlString.c_str());
     使用Parse函数就可以解析XML字符流了,这是很多开发者不太熟悉的情况。
    如果开发者开发特定应用,就可以使用上述类似方法,可能不需要完全处理每一个属性,比如可以对属性名进行判断,只处理自己需要的属性,或者自己需要的xml元素。还可以使用TinyXML的方法创建xml元素和xml属性,或者设置xml元素和属性对应的值,等等,如果读者想要类似的例子,可以留言写出。
     下面介绍TinyXML的一些类。在
TinyXML中,根据XML的各种元素来定义了一些类:
           TiXmlBase:整个TinyXML模型的基类。
TiXmlAttribute:对应于XML中的元素的属性。
TiXmlNode:对应于DOM结构中的节点。
TiXmlComment:对应于XML中的注释
TiXmlDeclaration:对应于XML中的申明部分,<?versiong="1.0" ?>。
TiXmlDocument:对应于XML的整个文档。
TiXmlElement:对应于XML的元素。
TiXmlText:对应于XML的文字部分
TiXmlUnknown:对应于XML的未知部分。 
        TiXmlHandler:定义了针对XML的一些操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值