通过C++开源库TinyXML2解析和生成XML数据

本文详细介绍了TinyXML2库,一个高效的C++XML解析和生成工具,包括加载文件、获取和设置节点数据、操作XML元素以及生成XML文件的示例。
摘要由CSDN通过智能技术生成

1 TinyXML2介绍

  • TinyXML2是一个轻量级的、开源的C++库,专门用于解析和生成XML文档。它是原始TinyXML库的一个升级版本,设计得更为高效和强大,同时保持了简单易用的特点。TinyXML2非常适合那些需要处理XML数据,而又希望保持代码简洁和执行效率的应用场景。

2 相关API

  • 2.1 加载文件

    •   /*
        *  @brief  加载XML文件
        *  @param  [IN]  filename  文件名
        *  @return 返回XML_SUCCESS表示成功,返回其他值表示失败
        */
        XMLError LoadFile(const char* filename);
      
  • 2.2 获取XML数据的根节点

    •   /*
        *  @brief  获取XML数据的根节点
        *  @return 成功返回XML数据的根节点对象,失败返回NULL
        */
        XMLElement* RootElement();
      
  • 2.3 获取XML数据的指定节点

    •   /*
        *  @brief  获取XML数据的指定节点
        *  @param  [IN]  name  指定节点名称,不传或传0时获取根节点对象
        *  @return 成功返回XML数据的指定节点对象,失败返回NULL
        */
        XMLElement* FirstChildElement(const char* name = 0);
      
  • 2.4 获取某个XML节点的文本内容

    •   /*
        *  @brief  获取XML元素的文本内容
        *  @return 返回XML元素的文本内容
        */
        const char* GetText() const;
      
  • 2.5 获取某个XMl节点的属性

    •   /*
        *  @brief  获取XML数据某个节点的属性
        *  @param  [IN]  name  属性名
        *  @return 返回某个节点属性值
        */
        const char* Attribute(const char* name) const;
      
  • 2.6 将新创建的节点添加到指定父节点

    •   /*
        *  @brief  将新创建的节点添加到指定父节点
        *  @param  [IN]  addThis  要添加到父节点的对象
        *  @return c成功返回插入的节点自身,失败返回NULL
        */
        XMLNode* InsertEndChild(XMLNode* addThis);
      
  • 2.7 创建新的XMLElement对象

    •   /*
        *  @brief  创建新的XMLElement对象  
        *  @param  [IN]  name  新元素的标签名称
        *  @return 成功返回指向新创建的XMLElement对象的指针, 失败返回NULL
        */
        XMLElement* NewElement(const char* name);
      
  • 2.8 设置某个XML节点的文本内容

    •   /*
        *  @brief  设置某个XML节点的文本内容
        *  @param  [IN]  inText  要设置的文本内容
        */
        void SetText(const char* inText);
      
  • 2.9 保存XML数据到文件中

    •   /*
        *  @brief  保存XML数据到文件中
        *  @param  [IN]  filename  文件名
        *  @return 返回XML_SUCCESS表示成功,返回其他值表示失败
        */
        XMLError SaveFile(const char* filename);
      

3 演示

3.1 解析XML数据

  • XML数据内容
    •   <?xml version="1.0"?>
        <msg>
            <msg_id>1</msg_id>
            <header hattr="http">
                <type>Post</type>
                <host>127.0.0.1</host>
            </header>
            <body battr="base64">
                <data>aGVsbG8=</data>
            </body>
        </msg>
      
  • 代码
    •   #include <stdio.h>
        #include <iostream>
        #include <tinyxml2.h>
      
        int main(){
            tinyxml2::XMLDocument xmlObj;
      
            // 解析数据
            //const char* xmlData = "<msg></msg>";
            //tinyxml2::XMLError errCode = xmlObj.Parse(xmlData);
            
            // 解析文件
            tinyxml2::XMLError errCode = xmlObj.LoadFile("xmldata.txt");
            if(errCode != tinyxml2::XML_SUCCESS){
                printf("LoadFile xml failed, errCode = %d\n", errCode);
                return -1;
            }
      
            // 获取根节点
            tinyxml2::XMLElement* root = xmlObj.RootElement();
            if (!root) {
                std::cout << "Invalid document structure." << std::endl;
                return -1;
            }
      
            // msg_id
            tinyxml2::XMLElement* msgidElem  = root->FirstChildElement("msg_id");
            if(msgidElem != NULL){
                const char* cMsgid = msgidElem->GetText();
                printf("cMsgid: %s\n", cMsgid);
            }
      
      
            // 遍历header元素
            for (tinyxml2::XMLElement* headerElem = root->FirstChildElement("header"); headerElem != nullptr; headerElem = headerElem->NextSiblingElement("header")) {        
                // 获取属性
                const char* cHattr = headerElem->Attribute("hattr");
                printf("cHattr: %s\n", cHattr);
      
                // 获取字段值
                tinyxml2::XMLElement* typeElem = headerElem->FirstChildElement("type");
                if(typeElem != NULL){
                    const char* cType = typeElem->GetText();
                    printf("cType: %s\n", cType);
                }                            
      
                tinyxml2::XMLElement* hostElem = headerElem->FirstChildElement("host");
                if(hostElem != NULL){
                    const char* cHost = hostElem->GetText();
                    printf("cHost: %s\n", cHost);
                }  
            }
      
            // 遍历body元素
            for (tinyxml2::XMLElement* bodyElem = root->FirstChildElement("body"); bodyElem != nullptr; bodyElem = bodyElem->NextSiblingElement("body")) {        
                // 获取属性
                const char* cBattr = bodyElem->Attribute("battr");
                printf("cBattr: %s\n", cBattr);
      
                // 获取字段值
                tinyxml2::XMLElement* dataElem = bodyElem->FirstChildElement("data");
                if(dataElem != NULL){
                    const char* cData = dataElem->GetText();
                    printf("cData: %s\n", cData);
                }                             
            }
      
            return 0;
        }
      
  • 打印
    • 在这里插入图片描述

3.2 生成XML数据

  • 代码
    •   #include <stdio.h>
        #include <iostream>
        #include <tinyxml2.h>
      
        int main(){
            // 初始化XML文档对象
            tinyxml2::XMLDocument doc;
            doc.InsertEndChild(doc.NewDeclaration()); // 添加XML声明
      
            // 创建根节点
            tinyxml2::XMLElement* root = doc.NewElement("msg");
            doc.InsertEndChild(root);
      
            // 在根节点下添加msg_id节点
            tinyxml2::XMLElement* msgidElem = doc.NewElement("msg_id");
            msgidElem->SetText("1");
            root->InsertEndChild(msgidElem);
      
      
            // 在根节点下添加header节点
            tinyxml2::XMLElement* headerElem = doc.NewElement("header");
            headerElem->SetAttribute("hattr", "http");
            root->InsertEndChild(headerElem);
      
            // header节点下添加type节点
            tinyxml2::XMLElement* typeElem = doc.NewElement("type");
            typeElem->SetText("Post");
            headerElem->InsertEndChild(typeElem);
            
            // header节点下添加host节点
            tinyxml2::XMLElement* hostElem = doc.NewElement("host");
            hostElem->SetText("127.0.0.1");
            headerElem->InsertEndChild(hostElem);
      
            // 在根节点下添加body节点
            tinyxml2::XMLElement* bodyElem = doc.NewElement("body");
            bodyElem->SetAttribute("battr", "base64");
            root->InsertEndChild(bodyElem);
      
            // body节点下添加data节点
            tinyxml2::XMLElement* dataElem = doc.NewElement("data");
            dataElem->SetText("aGVsbG8=");
            bodyElem->InsertEndChild(dataElem);
      
            // 保存到文件
            doc.SaveFile("example.xml");
      
            return 0;
        }
      
  • 生成的XML数据
    •   <?xml version="1.0" encoding="UTF-8"?>
        <msg>
            <msg_id>1</msg_id>
            <header hattr="http">
                <type>Post</type>
                <host>127.0.0.1</host>
            </header>
            <body battr="base64">
                <data>aGVsbG8=</data>
            </body>
        </msg>
      
  • 31
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: tinyxml2是一个开源的、轻量级的XML解析。它是对C++标准的简单封装,用于处理XML文件的读取、解析以及创建和修改XML文件。 tinyxml2具有以下特点和功能: 1. 易于使用:tinyxml2的API设计简单、易于理解和操作,可以方便地读取和解析XML文件中的数据。 2. 快速且内存占用低:tinyxml2使用了基于迭代器的解析算法,解析速度快,而且内存占用较小。 3. 跨平台兼容性:tinyxml2可以在不同的操作系统和编译器上运行,具有良好的跨平台兼容性。 4. 支持Unicode:tinyxml2支持Unicode编码的XML文件,可以正确地处理各种国际化字符。 5. 支持创建和修改XML文件:tinyxml2可以方便地创建和修改XML文件,可以添加、删除和修改XML节点及其属性。 6. 错误处理能力强:tinyxml2提供了丰富的错误处理机制,可以捕获和处理解析XML文件中的错误。 7. 可靠性高:tinyxml2解析XML文件时具有良好的鲁棒性,可以处理复杂的XML文件结构和错误格式的XML文件。 总之,tinyxml2是一个功能强大、可靠高效的XML解析,适用于各种C++项目中需要处理XML文件的场景。无论是读取、解析、创建还是修改XML文件,tinyxml2都提供了简单易用的API,并且具有较好的跨平台兼容性和Unicode支持。 ### 回答2: TinyXML2是一个轻量级的C++,用于解析生成XML文档。它是TinyXML的升级版本,提供了更好的性能和易于使用的API。 TinyXML2具有简单直观的接口,支持XML的基本操作,如加载、解析、访问和修改XML文档。它提供了一些类和函数,可以方便地在代码中处理XML数据TinyXML2支持从文件、字符串和内存中加载XML文档。它可以解析XML元素、属性、文本内容和注释,并提供了访问和修改这些数据的接口。用于访问和修改XML数据的API是面向对象的,使得操作XML文档更加方便和直观。 TinyXML2还提供了将XML文档序列化为字符串的功能,以及将XML数据写入到文件中的功能。这使得可以方便地将XML文档保存到文件或其他储存介质中,或者将XML数据通过网络传输。 TinyXML2使用C++语言编写,具有良好的可移植性和跨平台性。它不依赖于任何外部,只需要包含头文件即可使用。这使得它非常适合用于嵌入式系统或其他资源有限的环境中。 总之,TinyXML2是一个功能强大、易于使用的C++,用于解析生成XML文档。它提供了简单直观的API,支持XML的基本操作,同时具有良好的可移植性和跨平台性。无论是在桌面应用程序、嵌入式系统还是其他需要处理XML的项目中,TinyXML2都是一个很好的选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大草原的小灰灰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值