【QT】增删改查 XML 文件的类

使用单例类模板实现的对XML文件的节点、属性、文本进行增删改查,可以直接用!
直接POST代码,比较简单好用。
头文件

#pragma once
#include "SingletonCRTP.h"
#include <stdio.h>
#include <iostream>
#include <QObject>
#include <QXmlStreamReader>
#include <QFile>
#include <QtXml\QDomComment>
#include <QDir>
#include <QTextStream>
#include <QCoreApplication>

class XmlHelper: public SingletonCRTP<XmlHelper>
{
	friend class SingletonCRTP<XmlHelper>;


public:
    explicit XmlHelper(const QString& xmlFilePath);
    XmlHelper() {};
    bool loadXml(const QString& filePath);

    QString getNode(const QString& nodeName) const;
    QStringList getNodes(const QString& nodeName) const;
    QStringList getChildNodes(const QString& nodeName) const;

    QStringList getNodes(const QString& nodeName, const QString& attrName) const;
    QString getAttribute(const QString& nodeName, const QString& attrName) const;
    QStringList getAttributes(const QString& nodeName, const QString& attrName) const;
    QString getText(const QString& nodeName) const;
    bool setNodeText(const QString& nodeName, const QString& text);
    bool setNodeAttribute(const QString& nodeName, const QString& attrName, const QString& attrValue);
    bool addNode(const QString& nodeName, const QString& text);
    bool removeNode(const QString& nodeName);
    bool saveToFile(const QString& filePath);
    bool save();

private:
    QDomDocument xmldoc;
    QFile xmlFile;
    QDomNode findFirstNode(const QString& nodeName) const;

};

源文件

#include "XmlHelper.h"
#include <QDomElement>
#include <QDomNodeList>
#include <QXmlStreamReader>

XmlHelper::XmlHelper(const QString& xmlFilePath)
{
	loadXml(xmlFilePath);
}


bool XmlHelper::loadXml(const QString& filePath)
{
	xmlFile.setFileName(filePath);
	if (!xmlFile.open(QIODevice::ReadOnly | QIODevice::Text))
	{
		return false;
	}

	QXmlStreamReader xmlReader(&xmlFile);
	if (!xmldoc.setContent(&xmlReader, true))
	{
		xmlFile.close();
		return false;
	}
	xmlFile.close();


	return true;
}

QDomNode XmlHelper::findFirstNode(const QString& nodeName) const
{
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	if (!nodeList.isEmpty())
	{
		return nodeList.at(0);
	}
	return QDomNode();
}

QString XmlHelper::getNode(const QString& nodeName) const
{
	QDomNode node = findFirstNode(nodeName);
	if (!node.isNull())
	{
		QDomElement element = node.toElement();
		return element.tagName();
	}
	return QString();
}

QStringList XmlHelper::getNodes(const QString& nodeName) const
{
	QStringList nodeNames;
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	for (int i = 0; i < nodeList.size(); ++i)
	{
		QDomElement element = nodeList.at(i).toElement();
		nodeNames.append(element.tagName());
	}
	return nodeNames;
}

QStringList XmlHelper::getChildNodes(const QString& nodeName) const
{
	QStringList nodeNames;
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	for (int i = 0; i < nodeList.size(); ++i)
	{
		QDomElement element = nodeList.at(i).toElement();
		QDomNodeList childs = element.childNodes();
		for (int j = 0; j < childs.size(); ++j)
		{
			if (childs.at(j).toElement().tagName() != "")
			{
				nodeNames.append(childs.at(j).toElement().tagName());
			}
		}
	}
	return nodeNames;
}

QStringList XmlHelper::getNodes(const QString& nodeName, const QString& attrName) const
{
	QStringList nodeNames;
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	for (int i = 0; i < nodeList.size(); ++i)
	{
		QDomElement element = nodeList.at(i).toElement();
		if (element.attribute("name") == attrName)
		{
			nodeNames.append(element.tagName());
		}
	}
	return nodeNames;
}

QString XmlHelper::getAttribute(const QString& nodeName, const QString& attrName) const
{
	QDomNode node = findFirstNode(nodeName);
	if (!node.isNull())
	{
		QDomElement element = node.toElement();
		return element.attribute(attrName);
	}
	return QString();
}

QStringList XmlHelper::getAttributes(const QString& nodeName, const QString& attrName) const
{
	QStringList attrValues;
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	for (int i = 0; i < nodeList.size(); ++i)
	{
		QDomElement element = nodeList.at(i).toElement();
		if (element.hasAttribute(attrName))
		{
			attrValues.append(element.attribute(attrName));
		}
	}
	return attrValues;
}

QString XmlHelper::getText(const QString& nodeName) const
{
	QDomNode node = findFirstNode(nodeName);
	if (!node.isNull())
	{
		QDomElement element = node.toElement();
		return element.text();
	}
	return QString();
}


bool XmlHelper::setNodeText(const QString& nodeName, const QString& text)
{
	QDomNode node = findFirstNode(nodeName);
	if (!node.isNull())
	{
		QDomNode oldnode = node.firstChild();
		node.firstChild().setNodeValue(text);
		QDomNode newnode = node.firstChild();     //值修改过后
		node.replaceChild(newnode, oldnode);      //调用节点的replaceChild方法实现修改功能

		return true;
	}
	return false;
}

bool XmlHelper::setNodeAttribute(const QString& nodeName, const QString& attrName, const QString& attrValue)
{
	QDomNode node = findFirstNode(nodeName);
	if (!node.isNull())
	{
		QDomElement element = node.toElement();
		element.setAttribute(attrName, attrValue);
		return true;
	}
	return false;
}

bool XmlHelper::addNode(const QString& nodeName, const QString& text)
{
	QDomElement root = xmldoc.documentElement();
	QDomElement newNode = xmldoc.createElement(nodeName);
	newNode.appendChild(xmldoc.createTextNode(text));
	root.appendChild(newNode);
	return true;
}

bool XmlHelper::removeNode(const QString& nodeName)
{
	QDomNodeList nodeList = xmldoc.elementsByTagName(nodeName);
	for (int i = 0; i < nodeList.size(); ++i)
	{
		QDomNode node = nodeList.at(i);
		node.parentNode().removeChild(node);
	}
	return true;
}

bool XmlHelper::saveToFile(const QString& filePath)
{
	QFile file(filePath);

	if (!file.open(QFile::WriteOnly | QFile::Truncate | QFile::Text))
	{
		return false;
	}
	try
	{
		QTextStream stream(&file);
		stream.setCodec("utf-8");
		xmldoc.save(stream, 4, QDomNode::EncodingFromTextStream);
		file.close();
		return true;
	}
	catch (const std::exception&)
	{
		return false;
	}
}

bool XmlHelper::save()
{
	if (!xmlFile.open(QFile::WriteOnly | QFile::Truncate | QFile::Text))
	{
		return false;
	}
	try
	{
		QTextStream stream(&xmlFile);
		stream.setCodec("utf-8");
		xmldoc.save(stream, 4, QDomNode::EncodingFromTextStream);
		xmlFile.close();
		return true;
	}
	catch (const std::exception& e)
	{
		std::cout << e.what() << std::endl;
		return false;
	}
}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/947797.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue导入导出excel、设置单元格文字颜色、背景色、合并单元格(使用xlsx-js-style库)

npm i xlsx-js-style <template><button click"download">下载 Excel 表格</button><el-table :data"tableData" style"width: 100%"><el-table-column prop"date" label"日期" width"180…

Ansys Discovery 中的网格划分方法:探索模式

本篇博客文章将介绍 Ansys Discovery 中可用于在探索模式下进行分析的网格划分方法。我们将在下一篇博客中介绍 Refine 模式下的网格划分技术。 了解 Discovery Explore 模式下的网格划分 网格划分是将几何模型划分为小单元以模拟系统在不同条件下的行为的过程。这是通过创建…

Android布局layout的draw简洁clipPath实现圆角矩形布局,Kotlin

Android布局layout的draw简洁clipPath实现圆角矩形布局&#xff0c;Kotlin 通常&#xff0c;如果要把一个相对布局&#xff0c;FrameLayout&#xff0c;或者线性布局等这样的布局变成具有圆角或者圆形的布局&#xff0c;需要增加一个style&#xff0c;给它设置圆角&#xff0c;…

【中间件】docker+kafka单节点部署---zookeeper模式

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言消息中间件介绍1. KRaft模式2. zookeeper模式2.1. 单节点部署安装验证 前言 最近生产环境上准备部署ELFK日志监控&#xff0c;先在测试环境部署单节点kafka验证…

38 Opencv HOG特征检测

文章目录 HOGDescriptor 构造函数setSVMDetector 设置支持向量机&#xff08;SVM&#xff09;检测器&#xff0c;用于目标检测。compute 用于计算图像区域的HOG描述符。detectMultiScale 多尺度检测目标。示例 HOGDescriptor 构造函数 HOGDescriptor(); HOGDescriptor(const S…

音视频-----RTSP协议 音视频编解码

流媒体协议详解&#xff1a;RTSP、RTP、RTCP、SIP、SDP、RTMP、WebRTC、WebSocket-CSDN博客 上文讲解比较清楚 多媒体编解码基础知识 一文详解WebRTC、RTSP、RTMP、SRT-腾讯云开发者社区-腾讯云 RTP :(Real-time Transport Protocol)是用于Internet上针对多媒体数据流的一种传…

著名的软件都用什么语言编写?

你是否曾经好奇&#xff0c;身边那些耳熟能详的软件&#xff0c;它们究竟是用什么语言编写的&#xff1f;从操作系统到浏览器、从数据库到编程工具&#xff0c;每一款软件背后都承载着开发者们的智慧与技术选型。那么&#xff0c;究竟哪些编程语言成就了这些世界级的软件呢&…

高效自携式潜水装备,助力水下探索|鼎跃安全

水域安全是水上作业、救援和科研活动的重要保障&#xff0c;面对复杂多变的水下环境&#xff0c;一套轻便、高效的全能的智能设备&#xff0c;能在极大的程度上给潜水活动提供保障。传统潜水装备因体积庞大、操作复杂&#xff0c;已无法满足多样化任务需求。自携式潜水装备凭借…

uni-app深度解码:跨平台APP开发的核心引擎与创新实践

在当今数字化浪潮中&#xff0c;移动应用市场呈现出爆炸式增长。为了满足不同用户群体在不同操作系统上的需求&#xff0c;跨平台 APP 开发成为众多开发者的首选策略。uni-app 作为一款领先的跨平台开发框架&#xff0c;以其独特的优势和创新的实践在众多同类产品中脱颖而出。它…

【74HC192减法24/20/72进制】2022-5-17

缘由用74ls192设计一个72进制的减法计数器&#xff0c;需要有逻辑电路图-硬件开发-CSDN问答

第十届“挑战杯”大学生课外学术科技作品竞赛解析及资料

“挑战杯”被誉为大学生科技创新创业的“奥林匹克”盛会&#xff0c;它汇聚了来自各个学科、各个年级的精英人才。在这里&#xff0c;同学们带着对未知的好奇和对知识的渴望&#xff0c;组成一个个团队&#xff0c;向难题发起挑战。现在&#xff0c;第十届“挑战杯”大学生课外…

Linux实验报告14-Linux内存管理实验

目录 一&#xff1a;实验目的 二&#xff1a;实验内容 1、编辑模块的源代码mm_viraddr.c 2、编译模块 3、编写测试程序mm_test.c 4、编译测试程序mm_test.c 5、在后台运行mm_test 6、验证mm_viraddr模块 一&#xff1a;实验目的 (1)掌握内核空间、用户空间&#xff…

趣味编程:心形曲线

目录 1.序言 2.代码展示 3.代码详解 3.1 头文件包含 3.2 绘制坐标轴函数 3.3 main 函数主体部分 4. 小结 1.序言 2025年的第一篇博客就用这个笛卡尔心形图开篇吧&#xff0c;寓意着新年大家能够有心有所属&#xff0c;祝诸位程序猿 / 程序媛 能够早点遇到自己的另一半。…

Ansys Aqwa 中 Diffraction Analysis 的疲劳结果

了解如何执行疲劳分析&#xff0c;包括由 Ansys Aqwa 计算的海浪行为。 了解疲劳分析 大多数机器故障是由于负载随时间变化&#xff0c;而不是静态负载。这种失效通常发生在应力水平明显低于材料的屈服强度时。因此&#xff0c;当存在动态载荷时&#xff0c;仅依赖静态失效理…

CAD图块是什么?如何进行CAD图块分解?

CAD图块是CAD软件中的一个重要概念&#xff0c;它指的是由一组图形元素&#xff08;如点、线、弧、圆、多边形等&#xff09;组合而成的整体。在CAD画图中&#xff0c;为了能够简化操作、提高效率&#xff0c;保持设计的一致性&#xff0c;很多时候&#xff0c;我们会选择建立C…

黑马JavaWeb开发跟学(十四).SpringBootWeb原理

黑马JavaWeb开发跟学 十四.SpringBootWeb原理 SpingBoot原理1. 配置优先级2. Bean管理2.1 获取Bean2.2 Bean作用域2.3 第三方Bean 3. SpringBoot原理3.1 起步依赖3.2 自动配置3.2.1 概述3.2.2 常见方案3.2.2.1 概述3.2.2.2 方案一3.2.2.3 方案二 3.2.3 原理分析3.2.3.1 源码跟踪…

被催更了,2025元旦源码继续免费送

“时间从来不会停下&#xff0c;它只会匆匆流逝。抓住每一刻&#xff0c;我们才不会辜负自己。” 联系作者免费领&#x1f496;源&#x1f496;码。 三联支持&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;欢迎留言讨论 更多内容敬请期待。如有需要源码可以联系作者免…

Python基础语法(上)

目录 一、print函数及常量表达式 1.print函数 2.常量表达式 二、变量 1.定义变量的规则 2.python的动态类型特性 3.字符串 三、注释 四、input函数 1.input函数 2.变量类型转换 五、运算符 1.算数运算符 2.关系运算符 &#xff08;1&#xff09;整形的比较 &am…

2024 年度总结

时光荏苒&#xff0c;2024 年即将画上句号&#xff0c;回顾这一年的写博历程&#xff0c;有付出、有收获、有成长&#xff0c;也有诸多值得回味与反思的瞬间。 一、内容创作 主题涉猎&#xff1a;这一年&#xff0c;我致力于探索多样化的主题&#xff0c;以满足不同读者群体的…

汉王扫描王 2.9.16 |免费无广告的智能扫描软件,支持多种格式导出

汉王扫描王是一款功能全面的智能扫描软件&#xff0c;集成了文字识别、表格提取和文档转换等功能。它支持将文档转换为PDF、Word、Excel等多种格式&#xff0c;非常适合学生、教师、业务人员和财务工作者使用。该软件具备手机扫描仪功能&#xff0c;能够自动抠边、矫正文档&…