使用tinyxml向xml文件中插入数据

目前已有一个xml文件,内容如下所示。想要在这个文件中间插入一个数据。tinyxml库比较好用。

1.下载tinyxml库文件并添加进工程

在网上下载好tinyxml的库文件,然后放入项目目录中
在qt工程中点击【添加现有文件】,把这6个文件添加进来

2.使用库文件

(1)在h文件引用tinyxml.h

cpp 复制代码
#include "./tinyXML/tinyxml.h"

(2)在cpp文件中使用

cpp 复制代码
void MainWindow::addElement()
{
    TiXmlDocument* xmlDocument = new TiXmlDocument();
    if(!xmlDocument->LoadFile("E:/QT_project/tinyxml_test/test.xml")) //如果找不到xml文件
    {
        qDebug() << xmlDocument->ErrorDesc();
        qDebug() << "找不到XML文件" ;
    }


    //查找xml文件中第一个名为"学生信息"的节点
    TiXmlElement* rootElement = xmlDocument->FirstChildElement("学生信息");
    if(rootElement == nullptr) //如果不存在"学生信息"的节点
    {
        qDebug() << xmlDocument->ErrorDesc();
        delete xmlDocument;
        return;
    }
    if(rootElement)  // 如果存在"学生信息"的节点
    {
        //在此节点下新创建一个节点并链接
        TiXmlElement* xmlElement = new TiXmlElement("学生序号");
        rootElement->LinkEndChild(xmlElement); 

        //创建一个显示"姓名"的节点
        TiXmlElement* childElement = new TiXmlElement("姓名");
        xmlElement->LinkEndChild(childElement);
        TiXmlText* xmlText = new TiXmlText("张鹏");
        childElement->LinkEndChild(xmlText);

        //创建一个显示"年龄"的节点
        childElement = new TiXmlElement("年龄");
        xmlElement->LinkEndChild(childElement);
        xmlText = new TiXmlText("25");
        childElement->LinkEndChild(xmlText);
    }

    xmlDocument->SaveFile(); // 保存
    delete xmlDocument;
}

(3)运行结果

完整的QT工程我放在gitee里了,欢迎自取,给个star

相关推荐
Jing_jing_X19 分钟前
MCP (一)是什么?一文讲清 AI 如何连接现实世界
数据库·人工智能·oracle
阿凡观察站26 分钟前
2026年工程项目管理软件推荐:这5款主流产品值得关注
大数据·数据库·低代码·finebi·简道云
逸Y 仙X1 小时前
文章二十一:ElasticSearch 词项查询与调度查询实战
java·大数据·数据库·elasticsearch·搜索引擎
李李李勃谦1 小时前
鸿蒙PCBI 报表工具:连接数据库与可视化报表生成
数据库·华为·交互·harmonyos
czlczl200209252 小时前
MAX()和MIN()优化
数据库·mysql·性能优化
消失的旧时光-19432 小时前
SQL 第一篇:CRUD 实战,从 user 表开始写接口
数据库·sql·mysql
小江的记录本3 小时前
【Kafka核心】Kafka高性能的四大核心支柱:零拷贝、批量发送、页缓存、压缩
java·数据库·分布式·后端·缓存·kafka·rabbitmq
.小小陈.3 小时前
MySQL 核心基础:数据类型与表约束全解析
数据库·mysql
KmSH8umpK3 小时前
Redis分布式锁进阶第十二篇
数据库·redis·分布式
hERS EOUS3 小时前
MySQL 函数
数据库·mysql