通过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>
      
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大草原的小灰灰

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

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

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

打赏作者

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

抵扣说明:

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

余额充值