• TinyXml高速入门(一)


    作者:朱金灿
    来源: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文件的形式:



          上面的样例摘自《TinyXML Tutorial 中文指南》。上面有四个样例,你看到了xml文件的几种表现形式?我看到了本质来说只是是两种表现形式:属性值值在尖括号内,如<Window name="MainFrame" x="5" y="15" w="400" h="250" />和文本在尖括号外,如<Welcome>Welcome to MyApp</Welcome>,详细例如以下图:


    xml struct


         鉴于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的project文件,将其编译成一个静态库,debug版本号为:tinyxmld_STL.lib,然后開始測试tinyxml库。我的測试计划是这种:首先使用tinyxml库创建example4.xml,然后将其读出来,然后查询指定节点的属性或文本,再改动example4.xml(改动当中的一些节点值和删除当中一个节点,添加一个节点),然后再读出来以推断是否改动成功。详细是在VS 2005上新建一个控制台project:Test,注意使用多字节字符集进行编译,同一时候加入。首先是创建xml文件的代码:


        



           不知你注意到上面的规律没有?首先父节点连接字节点使用函数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文件的代码非常easy,代码例如以下:




       下次介绍使用tinyxml库对xml文件进行查询指定节点、删除指定节点、改动指定节点和添加节点的使用方法。

    參考文献:


    1.《TinyXML新手教程


    2. 《tinyxml 使用笔记与总结


    3. 《TinyXML Tutorial 中文指南

















  • 相关阅读:
    C puzzles详解【51-57题】
    C puzzles详解【46-50题】
    C puzzles详解【38-45题】
    C puzzles详解【34-37题】
    C puzzles详解【31-33题】
    C puzzles详解【26-30题】
    C puzzles详解【21-25题】
    C puzzles详解【16-20题】
    使用C++模板实现栈的求最小值功能
    模拟求幂运算,考虑的已经很周全了
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4297991.html
Copyright © 2020-2023  润新知