下载:

官方文档:http://www.grinninglizard.com/tinyxmldocs/index.html

中文翻译:http://www.cnblogs.com/kex1n/archive/2010/10/03/1841502.html

TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译。这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树。

DOM模型即文档对象模型,是将整个文档分成多个元素(如书、章、节、段等),并利用树型结构表示这些元素之间的顺序关系以及嵌套包含关系。

引用来自tinyXML文档

iXmlBase是所有类的基类,TiXmlNode、TiXmlAttribute两个类都继承来自TiXmlBase类,其中TiXmlNode类指的是所有被<...>...<.../>包括的内容,而xml中的节点又具体分为以下几方面内容,分别是声明、注释、节点以及节点间的文本,因此在TiXmlNode的基础上又衍生出这几个类TiXmlComment、TiXmlDeclaration、TiXmlDocument、TiXmlElement、TiXmlText、TiXmlUnknown,分别用来指明具体是xml中的哪一部分。TiXmlAttribute类不同于TiXmlNode,它指的是在尖括号里面的内容,像<... ***=...>,其中***就是一个属性。

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文件的代码:

  1. /*!
  2. * /brief 创建xml文件。
  3. *
  4. * /param XmlFile xml文件全路径。
  5. * /return 是否成功。true为成功,false表示失败。
  6. */
  7. bool CreateXml(std::string XmlFile)
  8. {
  9. // 定义一个TiXmlDocument类指针
  10. TiXmlDocument *pDoc = new TiXmlDocument;
  11. if (NULL==pDoc)
  12. {
  13. return false;
  14. }
  15. TiXmlDeclaration *pDeclaration = new TiXmlDeclaration(_T("1.0"),_T(""),_T(""));
  16. if (NULL==pDeclaration)
  17. {
  18. return false;
  19. }
  20. pDoc->LinkEndChild(pDeclaration);
  21. // 生成一个根节点:MyApp
  22. TiXmlElement *pRootEle = new TiXmlElement(_T("MyApp"));
  23. if (NULL==pRootEle)
  24. {
  25. return false;
  26. }
  27. pDoc->LinkEndChild(pRootEle);
  28. // 生成子节点:Messages
  29. TiXmlElement *pMsg = new TiXmlElement(_T("Messages"));
  30. if (NULL==pMsg)
  31. {
  32. return false;
  33. }
  34. pRootEle->LinkEndChild(pMsg);
  35. // 生成子节点:Welcome
  36. TiXmlElement *pWelcome = new TiXmlElement(_T("Welcome"));
  37. if (NULL==pWelcome)
  38. {
  39. return false;
  40. }
  41. pMsg->LinkEndChild(pWelcome);
  42. // 设置Welcome节点的值
  43. std::string strValue = _T("Welcome to MyApp");
  44. TiXmlText *pWelcomeValue = new TiXmlText(strValue);
  45. pWelcome->LinkEndChild(pWelcomeValue);
  46. // 生成子节点:Farewell
  47. TiXmlElement *pFarewell = new TiXmlElement(_T("Farewell"));
  48. if (NULL==pFarewell)
  49. {
  50. return false;
  51. }
  52. pMsg->LinkEndChild(pFarewell);
  53. // 设置Farewell节点的值
  54. strValue = _T("Thank you for using MyApp");
  55. TiXmlText *pFarewellValue = new TiXmlText(strValue);
  56. pFarewell->LinkEndChild(pFarewellValue);
  57. // 生成子节点:Windows
  58. TiXmlElement *pWindows = new TiXmlElement(_T("Windows"));
  59. if (NULL==pWindows)
  60. {
  61. return false;
  62. }
  63. pRootEle->LinkEndChild(pWindows);
  64. // 生成子节点:Window
  65. TiXmlElement *pWindow = new TiXmlElement(_T("Window"));
  66. if (NULL==pWindow)
  67. {
  68. return false;
  69. }
  70. pWindows->LinkEndChild(pWindow);
  71. // 设置节点Window的值
  72. pWindow->SetAttribute(_T("name"),_T("MainFrame"));
  73. pWindow->SetAttribute(_T("x"),_T(""));
  74. pWindow->SetAttribute(_T("y"),_T(""));
  75. pWindow->SetAttribute(_T("w"),_T(""));
  76. pWindow->SetAttribute(_T("h"),_T(""));
  77. // 生成子节点:Window
  78. TiXmlElement *pConnection = new TiXmlElement(_T("Connection"));
  79. if (NULL==pConnection)
  80. {
  81. return false;
  82. }
  83. pRootEle->LinkEndChild(pConnection);
  84. // 设置节点Connection的值
  85. pConnection->SetAttribute(_T("ip"),_T("192.168.0.1"));
  86. pConnection->SetAttribute(_T("timeout"),_T("123.456000"));
  87. pDoc->SaveFile(XmlFile);
  88. return true;
  89. }&nbsp;

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

  1. /*!
  2. * /brief 打印xml文件。
  3. *
  4. * /param XmlFile xml文件全路径。
  5. * /return 是否成功。true为成功,false表示失败。
  6. */
  7. bool PaintXml(std::string XmlFile)
  8. {
  9. // 定义一个TiXmlDocument类指针
  10. TiXmlDocument *pDoc = new TiXmlDocument();
  11. if (NULL==pDoc)
  12. {
  13. return false;
  14. }
  15. pDoc->LoadFile(XmlFile);
  16. pDoc->Print();
  17. return true;
  18. }

Handles

Where browsing an XML document in a robust way, it is important to check for null returns from method calls. An error safe implementation can generate a lot of code like:

  1. TiXmlElement* root = document.FirstChildElement( "Document" );
  2. if ( root )
  3. {
  4. TiXmlElement* element = root->FirstChildElement( "Element" );
  5. if ( element )
  6. {
  7. TiXmlElement* child = element->FirstChildElement( "Child" );
  8. if ( child )
  9. {
  10. TiXmlElement* child2 = child->NextSiblingElement( "Child" );
  11. if ( child2 )
  12. {
  13. // Finally do something useful.

Handles have been introduced to clean this up. Using the TiXmlHandle class, the previous code reduces to:

  1. TiXmlHandle docHandle( &document );
  2. TiXmlElement* child2 = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).Child( "Child", 1 ).ToElement();
  3. if ( child2 )
  4. {
  5. // do something useful

Which is much easier to deal with. See TiXmlHandle for more information.

xml文档;

  1. <?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
  2. <SearchMode ModeCount="">
  3. <Mode1 Name="Numbers" RECount="" Space="">
  4. <RE1>[-]{,}</RE1>
  5. <RE2>[-]{,}</RE2>
  6. </Mode1>
  7. <Mode2 Name="Lower_Case" RECount="" Space="">
  8. <RE1>[a-z]{,}</RE1>
  9. <RE2>[a-z]{,}</RE2>
  10. <RE3>[a-z]{,}</RE3>
  11. </Mode2>
  12. <Mode3 Name="Lower_Case_Num" RECount="" Space="">
  13. <RE1>[a-z0-]{,}</RE1>
  14. <RE2>[a-z0-]{,}</RE2>
  15. <RE3>[a-z0-]{,}</RE3>
  16. <RE4>[a-z0-]{,}</RE4>
  17. </Mode3>
  18. </SearchMode>
  1. bool GetNodePointerByName(TiXmlElement* pRootEle, const char* strNodeName, TiXmlElement* &destNode)
  2. { //根据结点名获取结点指针
  3. // 假如等于根节点名,就退出
  4. if ( == strcmp(strNodeName, pRootEle->Value()))
  5. {
  6. destNode = pRootEle;
  7. return true;
  8. }
  9.  
  10. TiXmlElement* pEle = pRootEle;
  11. for (pEle = pRootEle->FirstChildElement(); pEle; pEle = pEle->NextSiblingElement())
  12. {
  13. // 递归处理子节点,获取节点指针
  14. if ( != strcmp(pEle->Value(), strNodeName))
  15. {
  16. GetNodePointerByName(pEle, strNodeName, destNode);
  17. }
  18. else
  19. {
  20. destNode = pEle;
  21. printf("destination node name: %s\n", pEle->Value());
  22. return true;
  23. }
  24. }
  25. return false;
  26. }
  27.  
  28. int readXmlFile()
  29. {
  30. TiXmlDocument *pDoc = new TiXmlDocument();
  31. pDoc->LoadFile("xmlData.xml");
  32. TiXmlElement *RootElem = pDoc->RootElement();//root elem
  33.  
  34. TiXmlElement *pEle = NULL;
  35.  
  36. GetNodePointerByName(RootElem, "SearchMode", pEle);//找到值为searchmodes的节点
  37. if (!pEle)
  38. {
  39. cout << "can't find it" << endl;
  40. return ;
  41. }
  42. else
  43. cout << "find it!" << endl;
  44. //遍历该节点
  45. for (TiXmlElement *curEle = pEle->FirstChildElement(); curEle; curEle = curEle->NextSiblingElement())
  46. {
  47. cout << "node:value:" << curEle->Value() << " ";
  48.  
  49. TiXmlAttribute *pAttr = curEle->FirstAttribute();
  50. while (pAttr) //输出所有属性
  51. {
  52. cout << pAttr->Name() << ":" << pAttr->Value() << " ";
  53. pAttr = pAttr->Next();
  54. }
  55.  
  56. cout << endl;
  57.  
  58. for (TiXmlElement *regExElem = curEle->FirstChildElement(); regExElem; regExElem->NextSiblingElement()) //输出子元素的值
  59. {
  60. cout <<regExElem->FirstChild()->Value() << endl; 这块有问题,死循环
  61. }
  62.  
  63. }
  64. delete pDoc;
  65. return ;
  66. }

  1. attr = elem->Attribute("priority");获取某个属性
  2. 参考:http://blog.csdn.net/L_Andy/article/details/40615517
    http://blog.csdn.net/mjay1234/article/details/7380536

tinyxml安装和使用的更多相关文章

  1. C++库(TinyXML)

    C++库(TinyXML) 什么是XML? "当 XML(扩展标记语言)于 1998 年 2 月被引入软件工业界时,它给整个行业带来了一场风暴.有史以来第一次,这个世界拥有了一种用来结构化文 ...

  2. [安卓]windows下如何安装Android源码

    本文改写于:http://www.cnblogs.com/skyme/archive/2011/05/14/2046040.html 1.下载并安装git: 在git-scm.com上下载并安装git ...

  3. centos 安装 mysql 5.6和workbench

    windows下安装mysql很简单,去官网找到.msi文件,一键安装就OK了. Centos下面安装Mysql5.6其实也是蛮简单的. 注意:centos6.5默认mysql版本是5.1的 1.添加 ...

  4. iOS平台XML解析类库对比和安装说明

    在iPhone开发中,XML的解析有很多选择,iOS SDK提供了NSXMLParser和libxml2两个类库,另外还有很多第三方类库可选,例如TBXML.TouchXML.KissXML.Tiny ...

  5. crtmpserver的安装,摄像头视频测试

    下载 svn co --username anonymous --password "" https://svn.rtmpd.com/crtmpserver/branches/1. ...

  6. LINUX配置过程记录(二) 工具安装

    安装谷歌游览 sudo apt-get update sudo apt-get install google-chrome-stable Ubuntu 16.04下源码安装Catkin https:/ ...

  7. 在Linux安装和使用LinuxBrew

    简介 LinuxBrew是流行的Mac OS X的一个Linux叉自制包管理器. LinuxBrew是包管理软件,它能从源(在Debian / Ubuntu的如"易/ DEB",并 ...

  8. 强化学习使用pygame模块的安装

    当你正想运行强化学习的游戏时,突然提示没有安装pygame模块怎么办呢? 其实很简单,通过下面的命令,就可以安装: D:\AI\sample\tensorforce>pip install py ...

  9. 怎么样在python 3.6里安装tensorflow?

    首先要下载python3.6: https://www.python.org/downloads/release/python-361/ 接着下载: numpy-1.13.0-cp36-none-wi ...

随机推荐

  1. Bootstrap页面布局21 - BS对话框设计

    设计弹出层对话框: 设计一个点击登录按钮,再弹出一个登陆对话框的实例,且带有动画效果 <div class='container-fluid'> <h2 class='page-he ...

  2. PHP学习(四)---PHP与数据库MySql

    主要有以下的内容: 1.怎么连接数据库 2.怎么操作数据库 (1)怎么执行sql语言 (2)怎么处理返回的结果集 方法一:面向过程(已经过时,只是了解) 假设: $username=your_name ...

  3. but this usually doesn’t gain you anything.

    High Performance My SQL, Third Edition Date and Time Types My SQL has many types for various kinds o ...

  4. Delphi 的绘图功能[1] - PolyBezier、PolyBezierTo

    双击代码全选 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 unit Unit1; interface uses Windows, Messages, SysUtils ...

  5. js 和 jquery 获取页面和滚动条的高度 视口高度文档高度

    js 和 jquery 获取页面和滚动条的高度 //页面位置及窗口大小 function GetPageSize() { var scrW, scrH; if(window.innerHeight & ...

  6. 如何在外网中访问自己在另一个局域网中的某个机器(SSH为例)

    UBUNTU 14.04 LTS 为例 如何在外网中访问自己在另一个局域网中的某个机器(SSH为例) 2013-05-01 16:02 2693人阅读 评论(0) 收藏 举报 情景描述: 计算机C1放 ...

  7. 删除win7中的库/收藏夹/家庭组/网络

    通过修改注册表删除库/收藏夹/家庭组/网络(还是不习惯库的这种管理方式, 导航里面又太占地方) 库:[HKEY_CLASSES_ROOT\CLSID\{031E4825-7B94-4dc3-B131- ...

  8. php判断爬虫

    function checkrobot($useragent = ''){ static $kw_spiders = 'Bot|Crawl|Spider|slurp|sohu-search|lycos ...

  9. 使用VC2005编译真正的静态Qt程序

    首先,你应该该知道什么叫静态引用编译.什么叫动态引用编译.我这里只是简单的提提,具体的可以google一下. 动态引用编译,是指相关的库,以dll的形式引用库.动态编译的Exe程序尺寸比较小,因为相关 ...

  10. c# ToString() 用法

    string tempa = Convert.ToString(31, 2);//将10进制数31转换为2进制字符串. string strNums = int.Parse(tempa).ToStri ...