使用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

相关推荐
稚辉君.MCA_P8_Java4 小时前
JVM第二课:一文讲透运行时数据区
jvm·数据库·后端·容器
阳光明媚sunny5 小时前
Room持久化库中,@Transaction注解的正确使用场景是?
android·数据库
北极糊的狐5 小时前
MySQL常见报错分析及解决方案总结(15)---Can’t connect to MySQL server on ‘localhost‘ (10061)
数据库·mysql
濑户川5 小时前
Django5 与 Vue3 表单交互全解析:从基础到实战
数据库
weixin_438077496 小时前
langchain官网翻译:Build a Question/Answering system over SQL data
数据库·sql·langchain·agent·langgraph
-雷阵雨-7 小时前
MySQL——数据库操作攻略
数据库·mysql
krielwus7 小时前
Oracle ORA-01653 错误检查以及解决笔记
数据库·oracle
Wadli7 小时前
csdn| MySQL
数据库·mysql
程序员水自流7 小时前
MySQL InnoDB存储引擎关键核心特性详细介绍
java·数据库·mysql
-雷阵雨-7 小时前
MySQL——表的操作
数据库·mysql