zoukankan      html  css  js  c++  java
  • TinyXML:一个优秀的C++ XML解析器


    读取和设置xml配置文件是最常用的操作,试用了几个C++XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好。

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

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

    如下是一个XML片段:
       <Persons>
            
    <Person ID="1">
                
    <name>周星星</name>
                
    <age>20</age>
            
    </Person>
            
    <Person ID="2">
                
    <name>白晶晶</name>
                
    <age>18</age>
            
    </Person>
        
    </Persons>

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

    TinyXML是个解析库,主要由DOM模型类(TiXmlBaseTiXmlNodeTiXmlAttributeTiXmlCommentTiXmlDeclarationTiXmlElementTiXmlTextTiXmlUnknown)和操作类(TiXmlHandler)构成。它由两个头文件(.h文件)和四个CPP文件(.cpp文件)构成,用的时候,只要将(tinyxml.htinystr.htinystr.cpptinyxml.cpptinyxmlerror.cpptinyxmlparser.cpp)导入工程就可以用它的东西了。如果需要,可以将它做成自己的DLL来调用。举个例子就可以说明一切。。。

    对应的XML文件:
    <Persons>
        
    <Person ID="1">
            
    <name>phinecos</name>
            
    <age>22</age>
        
    </Person>
    </Persons>

    读写XML文件的程序代码:

    #include <iostream>
    #include 
    "tinyxml.h"
    #include 
    "tinystr.h"
    #include 
    <string>
    #include 
    <windows.h>
    #include 
    <atlstr.h>
    using namespace std;

    CString GetAppPath()
    {//获取应用程序根目录
        TCHAR modulePath[MAX_PATH];
        GetModuleFileName(NULL, modulePath, MAX_PATH);
        CString strModulePath(modulePath);
        strModulePath 
    = strModulePath.Left(strModulePath.ReverseFind(_T('\\')));
        
    return strModulePath;
    }


    bool CreateXmlFile(string& szFileName)
    {//创建xml文件,szFilePath为文件保存的路径,若创建成功返回true,否则false
        try
        
    {
            
    //创建一个XML的文档对象。
            TiXmlDocument *myDocument = new TiXmlDocument();
            
    //创建一个根元素并连接。
            TiXmlElement *RootElement = new TiXmlElement("Persons");
            myDocument
    ->LinkEndChild(RootElement);
            
    //创建一个Person元素并连接。
            TiXmlElement *PersonElement = new TiXmlElement("Person");
            RootElement
    ->LinkEndChild(PersonElement);
            
    //设置Person元素的属性。
            PersonElement->SetAttribute("ID""1");
            
    //创建name元素、age元素并连接。
            TiXmlElement *NameElement = new TiXmlElement("name");
            TiXmlElement 
    *AgeElement = new TiXmlElement("age");
            PersonElement
    ->LinkEndChild(NameElement);
            PersonElement
    ->LinkEndChild(AgeElement);
            
    //设置name元素和age元素的内容并连接。
            TiXmlText *NameContent = new TiXmlText("周星星");
            TiXmlText 
    *AgeContent = new TiXmlText("22");
            NameElement
    ->LinkEndChild(NameContent);
            AgeElement
    ->LinkEndChild(AgeContent);
            CString appPath 
    = GetAppPath();
            
    string seperator = "\\";
            
    string fullPath = appPath.GetBuffer(0+seperator+szFileName;
            myDocument
    ->SaveFile(fullPath.c_str());//保存到文件
        }

        
    catch (string& e)
        
    {
            
    return false;
        }

        
    return true;
    }


    bool ReadXmlFile(string& szFileName)
    {//读取Xml文件,并遍历
        try
        
    {
            CString appPath 
    = GetAppPath();
            
    string seperator = "\\";
            
    string fullPath = appPath.GetBuffer(0+seperator+szFileName;
            
    //创建一个XML的文档对象。
            TiXmlDocument *myDocument = new TiXmlDocument(fullPath.c_str());
            myDocument
    ->LoadFile();
            
    //获得根元素,即Persons。
            TiXmlElement *RootElement = myDocument->RootElement();
            
    //输出根元素名称,即输出Persons。
            cout << RootElement->Value() << endl;
            
    //获得第一个Person节点。
            TiXmlElement *FirstPerson = RootElement->FirstChildElement();
            
    //获得第一个Person的name节点和age节点和ID属性。
            TiXmlElement *NameElement = FirstPerson->FirstChildElement();
            TiXmlElement 
    *AgeElement = NameElement->NextSiblingElement();
            TiXmlAttribute 
    *IDAttribute = FirstPerson->FirstAttribute();
            
    //输出第一个Person的name内容,即周星星;age内容,即;ID属性,即。
            cout << NameElement->FirstChild()->Value() << endl;
            cout 
    << AgeElement->FirstChild()->Value() << endl;
            cout 
    << IDAttribute->Value()<< endl;
        }

        
    catch (string& e)
        
    {
            
    return false;
        }

        
    return true;
    }

    int main()
    {
        
    string fileName = "info.xml";
        CreateXmlFile(fileName);
        ReadXmlFile(fileName);
    }


    作者:洞庭散人

    出处:http://phinecos.cnblogs.com/    

    本博客遵从Creative Commons Attribution 3.0 License,若用于非商业目的,您可以自由转载,但请保留原作者信息和文章链接URL。

  • 相关阅读:
    深入探究JVM之垃圾回收器
    深入探究JVM之对象创建及分配策略
    深入探究JVM之内存结构及字符串常量池
    【深度思考】如何优雅告知用户,网站正在升级维护?
    Redis系列(九):Redis的事务机制
    [C#.NET 拾遗补漏]07:迭代器和列举器
    [C#.NET 拾遗补漏]06:单例模式最佳实践
    深入理解 EF Core:使用查询过滤器实现数据软删除
    简化RESTful开发,Spring Data REST让你少掉发
    如何查看Docker容器环境变量,如何向容器传递环境变量
  • 原文地址:https://www.cnblogs.com/phinecos/p/1100912.html
Copyright © 2011-2022 走看看