C++ XML解析之TinyXML篇

最近使用TinyXML进行C++ XML解析,感受使用起来比较简单,很容易上手,本文给出一个使用TinyXML进行XML解析的简单例子,不少复杂的应用均可以基于本例子的方法来完成。之后的文章里会讲解使用Xerces进行C++ XML解析的例子,但愿你们一块儿交流。
TinyXML是一个开源的解析XML的解析库,可以用于C++,可以在WindowsLinux中编译。这个解析库的模型经过解析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的一些操做。
相关文章
相关标签/搜索