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如下:

  <Class name="计算机软件班">

  <Students>

  <student name="张三" studentNo="13031001" sex="男" age="22">

  <phone>88208888</phone>

  <address>西安市太白南路二号</address>

  </student>

  <student name="李四" studentNo="13031002" sex="男" age="20">

  <phone>88206666</phone>

  <address>西安市光华路</address>

  </student>

  </Students>

  </Class>

  程序代码XmlParseExample.cpp如下所示:

  #include <iostream>

  #include <string>

  #include <tinyxml.h>

  using std::string;

  int main()

  {

  TiXmlDocument* myDocument = new TiXmlDocument();

  myDocument->LoadFile("Students.xml");

  TiXmlElement* rootElement = myDocument->RootElement(); //Class

  TiXmlElement* studentsElement = rootElement->FirstChildElement(); //Students

  TiXmlElement* studentElement = studentsElement->FirstChildElement(); //Students

  while ( studentElement ) {

  TiXmlAttribute* attributeOfStudent = studentElement->FirstAttribute(); // 获得student的name属性

  while ( attributeOfStudent ) {

  std::cout 《 attributeOfStudent->Name() 《 " : " 《 attributeOfStudent->Value() 《 std::endl;

  attributeOfStudent = attributeOfStudent->Next();

  }

  TiXmlElement* phoneElement = studentElement->FirstChildElement();// 获得student的phone元素

  std::cout 《 "phone" 《 " : " 《 phoneElement->GetText() 《 std::endl;

  TiXmlElement* addressElement = phoneElement->NextSiblingElement();

  std::cout 《 "address" 《 " : " 《 phoneElement->GetText() 《 std::endl;

  studentElement = studentElement->NextSiblingElement();

  }

  return 0;

  }

  程序运行 后果如下:

  name : 张三

  studentNo : 13031001

  sex : 男

  age : 22

  phone : 88208888

  address : 88208888

  name : 李四

  studentNo : 13031002

  sex : 男

  age : 20

  phone : 88206666

  address : 88206666

  本例中 使用的是对xml文件进行解析,很容易 主宰,然而众多开发人员不晓得如何对xml 字符流(非xml文件)进行解析,我看了TinyXML提供的源代码,里面 可以 使用如下 步骤对xml流解析 。对应于上例,代码如下:

  string xmlString =

  "<Class name=\"计算机软件班\">

  <Students>

  <student name=\"张三\" studentNo=\"13031001\" sex=\"男\" age=\"22\">

  <phone>88208888</phone>

  <address>西安市太白南路二号</address>

  </student>

  <student name=\"李四\" studentNo=\"13031002\" sex=\"男\" age=\"20\">

  <phone>88206666</phone>

  <address>西安市光华路</address>

  </student>

  </Students>

  </Class>";

  TiXmlDocument* myDocument = new TiXmlDocument();

  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的一些操作 。