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

详细介绍:(12)功能实现:Qt实战项目之读写配置文件

详细介绍:(12)功能实现:Qt实战项目之读写配置文件

        回顾上一节课的内容,我们成功解锁了.db项目文件的创建技能。这节课,就让我们趁热打铁,一起来学习如何打开已创建的.db 项目文件,通过实现打开文件关于两个功能进一步探索读写配置文件的实现。

课程目标

        本节课我们来学习读写配置文件,具体如下:

1、学习读写系统注册表、INI配置文件;

2、实现菜单栏的“文件-打开项目”按钮,读取系统注册表,默认显示出上一次打开的项目;

3、实现菜单栏的“帮助-关于”按钮,读INI配置文件获取信息;

定义打开文件的槽函数

        首先在SubCfgTool类中定义打开项目的槽函数,定义为openProject()。然后绑定按钮点击信号与打开项目的槽函数,此过程可以参考之前的学习内容。

connect(openProjAct, &QAction::triggered, this, &SubCfgTool::openProject);

        接下来我们来实现打开项目的主要逻辑,前面的课程中我们在创建项目的时候,用到了QFileDialog::getExistingDirectory()函数来获取项目的存放路径,这节课我们来使用QFileDialog的另外一个静态函数getOpenFileName()来返回用户选择的文件。

// 参数说明:
QString QFileDialog::getOpenFileName(QWidget *parent = nullptr,                // 父窗口const QString &caption = QString(),       // 对话框标题const QString &dir = QString(),           // 默认打开的目录const QString &filter = QString(),        // 文件类型过滤规则(如“数据库文件 (*.db);;文本文件 (*.txt)”)QString *selectedFilter = nullptr,        // 输出参数:用户选中的过滤规则(可选)QFileDialog::Options options = Options()  // 对话框选项(如是否显示详细信息、是否只读等,可选)
);

        选择.db文件后,再调用initDatabase()函数完成初始化。

void SubCfgTool::openProject()
{QString strFileName;strFileName = QFileDialog::getOpenFileName(this, QStringLiteral("打开项目"), "", QStringLiteral("项目文件(*.db)"));if (strFileName.isEmpty()){return;}else{DBManager::getInstance()->initDatabase(strFileName);}
}

定义关于的槽函数

        在SubCfgTool类中定义槽函数aboutDialog(),再绑定信号与槽函数。

connect(aboutAct, &QAction::triggered, this, &SubCfgTool::aboutDialog);

        槽函数的实现,将在接下来的内容中讲解。

void SubCfgTool::aboutDialog()
{
}

QSetting类

        我们用到一下新的类,QSettings 是 Qt 框架中用于轻松读写应用程序设置和配置的类。它提供了一种跨平台的方式来管理用户偏好、应用状态和持久化数据。在 Windows 系统中,它主要对接系统注册表(默认)或自定义 INI 文件,无需手动调用 Windows API 即可便捷操作系统级 / 应用级配置,是 Qt 开发中管理 Windows 配置的首选工具。

QSettings 操作系统注册表

        结合上面打开项目的函数,如果我们打开项目时,需要记住上一次打开的目录,应该怎么做。特别是一些经常性的打开操作,我们希望其能记住上一次的打开目录,即便是在程序重启以后,也依然能记住。这里我们引入一个新的QSetting类。

        像是记录上一次的打开目录这类配置信息,系统自动记录和读取即可,无需开放给用户编辑,所以这些配置信息我们统一放在注册表中存放,这些配置信息都是以键值的形式存储的,我们在DBManager类中封装两个函数,分别读取和写入

bool setRegedit(QString strKey, QString strValue);    // 写入键值
QString getRegedit(QString strKey);                   // 根据键获取配置信息

函数实现如下:

  • QSettings对象我们指定写入的位置"HKEY_CURRENT_USER\Software\SubCfgTool\LastRecord"。
  • 参数QSettings::NativeFormat 是 Qt 框架中用于指定配置文件存储格式的枚举值,它表示使用操作系统原生的配置存储方式。
bool DBManager::setRegedit(QString strKey, QString strValue)
{QSettings settings("HKEY_CURRENT_USER\\Software\\SubCfgTool\\LastRecord", QSettings::NativeFormat);settings.setValue(strKey, strValue);return true;
}
QString DBManager::getRegedit(QString strKey)
{QSettings settings("HKEY_CURRENT_USER\\Software\\SubCfgTool\\LastRecord", QSettings::NativeFormat);QString valueStr = settings.value(strKey).toString();return valueStr;
}

回到打开项目的函数,我们在每次打开文件之后,将路径信息写入到注册表

void SubCfgTool::openProject()
{// *****// ***** 以上为其他内容// 获取路径QFileInfo fileInfo(strFileName);QString dirPath = fileInfo.absolutePath();  // 例如:"D:/Documents/Images"// 写入注册表DBManager::getInstance()->setRegedit("LastDBFilePath", dirPath);
}

        同时,每次打开项目时,也要先查找一下注册表,看注册表中是否有记录上一次的打卡目录,并设置在QFileDialog::getOpenFileName的参数中,如下

void SubCfgTool::openProject()
{// 获取上一次打开的目录QString strLastDBFilePath = DBManager::getInstance()->getRegedit("LastDBFilePath");QString strFileName;strFileName = QFileDialog::getOpenFileName(this, QStringLiteral("打开项目"), strLastDBFilePath, QStringLiteral("项目文件(*.db)"));if (strFileName.isEmpty()){return;}else{DBManager::getInstance()->initDatabase(strFileName);}// 获取路径QFileInfo fileInfo(strFileName);QString dirPath = fileInfo.absolutePath();  // 例如:"D:/Documents/Images"// 写入注册表DBManager::getInstance()->setRegedit("LastDBFilePath", dirPath);
}

        编译运行测试效果,发现每次打开项目时,会自动定位到上一次打开的目录。

QSettings 操作 INI配置文件

        若不想操作注册表,也可以读写INI配置文件,INI 是轻量级文本配置文件,适合需用户手动修改、可便携迁移、轻量简单的配置。

        INI配置文件由节、键、值组成。同类的配置信息按照节组合在一起。

        我们定义一个程序的配置文件cfg.ini,放在应用程序的目录下。 Release和Debug目录都放置。我们在cfg配置文件中定义公司名称、软件名称、软件版本等基本信息。

[Base]
company = xiyou
toolname = SubCfgTool
version = 1.0.0
因为这个配置文件,主要以读取为主,所以我们只定义一个读取的函数。
  • QCoreApplication::applicationDirPath()用于获取当前程序的目录;
  • QSettings::IniFormat 表示使用 INI 格式 存储配置数据。
QString DBManager::getIniCfg(QString strKey)
{// 构建完整的INI文件路径QString configPath = QCoreApplication::applicationDirPath() + "/cfg.ini";// 检查文件是否存在if (!QFileInfo::exists(configPath)){qWarning() << "INI文件不存在:" << configPath;return QString();}// 使用 INI 文件格式QSettings settings(configPath, QSettings::IniFormat);QString valueStr = settings.value(strKey).toString();return valueStr;
}

        接下来我们来实现一下关于的函数aboutDialog(),该函数读出cfg.ini配置文件中的信息并展示。

QDialog aboutWin(this);aboutWin.setWindowTitle(QStringLiteral("关于..."));aboutWin.setFixedSize(320, 150);QString strCompany = QStringLiteral("公司:") + DBManager::getInstance()->getIniCfg("Base/company");QString strToolName = QStringLiteral("工具:") + DBManager::getInstance()->getIniCfg("Base/toolname");QString strVersion = QStringLiteral("版本:") + DBManager::getInstance()->getIniCfg("Base/version");QLabel* labelCompany = new QLabel(strCompany);QLabel* labelToolName = new QLabel(strToolName);QLabel* labelVersion = new QLabel(strVersion);QVBoxLayout* layout = new QVBoxLayout;layout->addWidget(labelCompany);layout->addWidget(labelToolName);layout->addWidget(labelVersion);layout->setContentsMargins(50, 25, 50, 25);aboutWin.setLayout(layout);aboutWin.exec();

运行效果如下:

http://www.jsqmd.com/news/204984/

相关文章:

  • LeetCode 面试经典 150_二分查找_搜索插入位置(111_35_C++_简单)
  • 2026年政务大厅智能化建设必备设备与硬件清单解析 - 智造出海
  • 2026年汽车4S店数字化转型必备智能设备全解析 - 智造出海
  • 网盘直链下载助手背后的秘密:如何用VibeThinker生成Python下载脚本
  • Zookeeper分布式锁实现原理讲解:配合代码片段逐步演示
  • 离散数学(1) | 6 | 谓词逻辑的基本概念
  • GEO优化公司如何选择?2026年北京市场5家实力服务商对比与推荐 - 十大品牌推荐
  • Swagger UI展示API接口:便于开发者快速接入
  • 揭秘Docker镜像标签混乱难题:3步构建清晰、可追溯的标签体系
  • 如何实现零停机部署?Docker Compose + Nginx热加载配置实战(稀缺方案曝光)
  • Docker容器部署失控后果有多严重(真实案例曝光)
  • HTML页面自动生成器?用VibeThinker解析需求并输出结构化代码
  • 发票开具申请:企业用户购买后的财务支持
  • Kibana可视化分析:洞察用户使用行为模式
  • Falco日志分析进阶之路:从入门规则到自定义检测策略(附实战案例)
  • 信泰楼文具市场口碑怎么样?信泰楼马克笔质量评价及年度文具定制企业推荐 - 工业品网
  • MongoDB存储历史记录:结构化保存问答对
  • Git commit规范难统一?AI模型帮你自动生成专业提交信息
  • C++精灵库是什么?看看这山东快板唱的。
  • Zabbix监控集成:传统运维体系兼容支持
  • 构建零碳园区的智慧核心:微电网能源管理系统如何破解能源协同与碳排难题
  • Windows用户也能用!WSL2中运行VibeThinker-1.5B完整指南
  • 揭秘Docker在边缘计算中的部署难题:3个关键步骤实现无缝落地
  • 2026八边封制袋机厂家十大排行榜:制袋机厂推荐与深度测评指南 - 工业品网
  • 容器资源突增却无告警?深度剖析Docker监控缺失的4个核心指标
  • 揭秘Docker微服务扩展难题:如何实现秒级扩容与稳定承载
  • Typora写作伴侣:实时调用VibeThinker验证数学表达式准确性
  • (容器安全日志分析黄金标准):Docker + Falco 架构深度解析
  • “高效助力学术质量:本科生论文抽检6大权威平台解析与智能查询指南“
  • 2026青少年管教学校TOP5权威推荐:江西宜春博智,科学矫正助力迷途青春回归正轨 - mypinpai