当前位置: 首页 > news >正文

XML读取和设置例子

在Qt C++中,可以使用Qt的 QDomDocument类来读取、更新和保存XML文件。这个类提供了对XML文档的强大操作能力,支持通过DOM(文档对象模型)对XML进行读取、修改、添加和删除节点等操作。
下面是一个详细的例子,演示如何在Qt中使用 QDomDocument来读取、更新一个XML文件,并保存修改后的XML文件。

例子:

假设我们有一个XML文件config.xml,内容如下:
<config><database><host>localhost</host><port>3306</port><user>root</user><password>password123</password></database><log><level>info</level></log>
</config>
我们需要做的操作是:
  1. 读取XML文件。
  2. 更新database/port为5432。
  3. 更新log/level为debug。
  4. 保存更新后的XML文件。

代码示例:

#include <QtCore>
#include <QDomDocument>
#include <QFile>
#include <QDebug>int main() {// 创建一个QFile对象,用于读取XML文件QFile file("config.xml");// 打开文件以进行读取if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {qDebug() << "Error opening file for reading";return -1;}// 创建一个QDomDocument对象用于解析XMLQDomDocument doc;// 读取XML内容并加载到QDomDocument中if (!doc.setContent(&file)) {qDebug() << "Error parsing XML file";file.close();return -1;}file.close();  // 关闭文件// 获取根元素(在这个例子中是)QDomElement root = doc.documentElement();// 获取元素QDomElement database = root.firstChildElement("database");// 获取并更新元素QDomElement portElement = database.firstChildElement("port");if (!portElement.isNull()) {portElement.firstChild().setNodeValue("5432");  // 更新端口号为5432}// 获取并更新元素中的QDomElement logElement = root.firstChildElement("log");QDomElement levelElement = logElement.firstChildElement("level");if (!levelElement.isNull()) {levelElement.firstChild().setNodeValue("debug");  // 更新日志级别为debug}// 保存修改后的XML文件QFile outFile("updated_config.xml");if (!outFile.open(QIODevice::WriteOnly | QIODevice::Text)) {qDebug() << "Error opening file for writing";return -1;}QTextStream out(&outFile);doc.save(out, 4);  // 使用4个空格的缩进来保存文件outFile.close();qDebug() << "XML file updated successfully!";return 0;
}

代码解释:

1. 读取XML文件
QFile file("config.xml");if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {qDebug() << "Error opening file for reading";return -1;
}
  • 使用QFile打开XML文件并以只读模式读取。
  • 如果文件无法打开,打印错误并退出程序。
2. 加载XML内容
QDomDocument doc;if (!doc.setContent(&file)) {qDebug() << "Error parsing XML file";file.close();return -1;
}
file.close();
  • 创建一个QDomDocument对象来解析XML文件内容。
  • setContent(&file)将文件内容加载到QDomDocument中。如果解析失败,输出错误并退出。
3. 获取根元素
QDomElement root = doc.documentElement();
  • documentElement()方法返回XML文档的根元素。在本例中,根元素是`config`。
4. 更新XML中的元素
QDomElement database = root.firstChildElement("database");
QDomElement portElement = database.firstChildElement("port");
if (!portElement.isNull()) {portElement.firstChild().setNodeValue("5432");
}
  • 使用firstChildElement("database")找到第一个`host`元素。
  • 使用firstChildElement("port")找到`port`元素。
  • 使用firstChild().setNodeValue("5432")更新`port`的值为5432。
同样地,更新log/level:
QDomElement logElement = root.firstChildElement("log");
QDomElement levelElement = logElement.firstChildElement("level");
if (!levelElement.isNull()) {levelElement.firstChild().setNodeValue("debug");
}
  • 使用firstChildElement("log")找到`log`元素。
  • 使用firstChildElement("level")找到`level`元素。
  • 使用firstChild().setNodeValue("debug")更新`level`的值为debug。
5. 保存修改后的XML文件
QFile outFile("updated_config.xml");
if (!outFile.open(QIODevice::WriteOnly | QIODevice::Text)) {qDebug() << "Error opening file for writing";return -1;
}QTextStream out(&outFile);
doc.save(out, 4);  // 使用4个空格的缩进来保存文件
outFile.close();
  • 创建一个新的QFile对象来保存修改后的XML文件。
  • doc.save(out, 4)将修改后的XML内容写入文件,使用4个空格进行缩进以增强可读性。
  • 保存完成后,关闭文件。
6. 程序输出
qDebug() << "XML file updated successfully!";
  • 如果所有操作都成功完成,输出一条成功消息。

总结:

  • 使用QFile读取XML文件,使用QDomDocument解析和修改XML内容。
  • 通过DOM操作(如firstChildElement()、setNodeValue()等)更新XML中的元素值。
  • 使用doc.save()将修改后的XML文件保存到磁盘。

相关文章:

  • 做网站维护挣钱吗合肥网站seo整站优化
  • 郑州做响应式网站/百度刷排名seo软件
  • 建设一个公司网站大概多少钱/什么网站可以发布广告
  • 网站开发工具/百度宣传做网站多少钱
  • 襄阳网站建设哪个好/重庆seo海洋qq
  • 做购物网站/admin5站长网
  • 人力资源紧张时,如何缓解项目推进瓶颈
  • Java的SpringAI+Deepseek大模型实战【二】
  • 飞往大厂梦之算法提升-7
  • Vue 列表过滤:语法与注意事项详解
  • Docker知识点汇总——AI教你学Docker
  • LINUX 623 FTP回顾
  • C++面向对象3——C++面向对象的权限、引用与指针
  • H5新增属性
  • logstash读取kafka日志写到oss归档存储180天
  • 2025年CSS最新高频面试题及核心解析
  • 边缘-云协同智能视觉系统:实时计算与云端智能的融合架构
  • Linux系统能ping通ip但无法ping通域名的解决方法
  • LeetCode热题100—— 160. 相交链表
  • [附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+Vue实现的校园二手交易平台管理系统,推荐!
  • Threejs实现 3D 看房效果
  • 【kubernetes】--controller(deployment)
  • 洛谷 P10379 [GESP202403 七级] 俄罗斯方块-普及/提高-
  • 使用Vue重新构建应用程序
  • UP COIN:从 Meme 共识走向公链与 RWA 的多元生态引擎
  • 浅析std::atomic<T>::compare_exchange_weak和std::atomic<T>::compare_exchange_strong