Qt 读取和写入 INI 格式的配置文件

article/2025/8/26 23:08:59

Qt 读取和写入 INI 格式的配置文件

  • 前言:INI 配置文件在 Qt 开发中的重要性
  • 基础夯实:INI 文件结构与 QSettings 核心概念
    • 1. INI 文件的基本结构
    • 2. QSettings 类概述
    • 3. 初始化 QSettings 对象
    • 4. 基本读写操作
    • 5. 高级操作技巧
      • 5.1 处理数组和列表
      • 5.2 检查键是否存在
      • 5.3 删除配置项
      • 5.4 同步操作
  • 实例效果展示:
  • 实现功能:
  • 核心代码:

前言:INI 配置文件在 Qt 开发中的重要性

在 Qt 应用程序开发中,配置文件是实现用户个性化设置与系统参数持久化的重要工具。INI (Initialization) 格式因其简洁的结构、跨平台兼容性和易于手动编辑的特性,成为存储应用程序配置的理想选择。通过 Qt 提供的QSettings类,开发者可以轻松实现 INI 文件的读写操作,无需关心底层实现细节,从而将更多精力投入到业务逻辑开发中。
本文将详细介绍如何使用 Qt 的QSettings类高效读写 INI 格式配置文件,涵盖基础操作、高级技巧及实际应用场景,帮助你在项目中更好地管理和维护配置信息。

基础夯实:INI 文件结构与 QSettings 核心概念

1. INI 文件的基本结构

INI 文件由三部分组成:
节 (Section):用方括号[]标识,用于分组相关配置项
键值对 (Key-Value):格式为Key=Value,存储具体配置信息
注释:以分号;或井号#开头的行,用于说明配置用途

[General]        ; 通用设置节
WindowSize=800x600
FullScreen=false[Network]        ; 网络设置节
ServerAddress=127.0.0.1
Port=8080[User]           ; 用户信息节
Name=John Doe
Email=john@example.com

2. QSettings 类概述

QSettings是 Qt 提供的用于读写配置文件的核心类,支持多种格式:
QSettings::IniFormat - INI 文本格式
QSettings::NativeFormat - 操作系统原生格式 (Windows 注册表 /macOS CFPreferences)
QSettings::JsonFormat - JSON 格式 (Qt 5.15+)
核心优势:
统一的 API 接口,屏蔽底层格式差异
自动处理数据类型转换
支持默认值机制
线程安全设计
支持嵌套分组结构

3. 初始化 QSettings 对象

创建操作 INI 文件的QSettings实例有两种方式:
方式一:全局应用程序范围 (推荐)

// 在main函数中设置应用程序信息
QCoreApplication::setOrganizationName("MyCompany");
QCoreApplication::setApplicationName("MyApp");// 使用全局设置
QSettings settings(QSettings::IniFormat, QSettings::UserScope, "MyCompany", "MyApp");
// 配置文件将自动保存到系统默认位置(如Windows: %APPDATA%\MyCompany\MyApp.ini)

方式二:指定文件路径

QSettings settings("config.ini", QSettings::IniFormat);
// 配置文件将保存在应用程序同级目录下

4. 基本读写操作

QSettings通过setValue()和value()方法实现配置项的读写:

// 写入配置
settings.setValue("General/WindowSize", "800x600");
settings.setValue("Network/ServerAddress", "127.0.0.1");
settings.setValue("User/LoggedIn", true);// 读取配置(带默认值)
QString windowSize = settings.value("General/WindowSize", "640x480").toString();
QString server = settings.value("Network/ServerAddress", "localhost").toString();
bool loggedIn = settings.value("User/LoggedIn", false).toBool();

关键特性:
使用/分隔节名和键名,支持嵌套结构
自动类型转换:支持 QString、int、bool、QVariant 等类型
写入操作自动触发文件保存,无需显式调用 save ()

5. 高级操作技巧

5.1 处理数组和列表

// 写入数组
settings.beginWriteArray("RecentFiles");
for (int i = 0; i < files.size(); ++i) {settings.setArrayIndex(i);settings.setValue("filePath", files[i]);
}
settings.endArray();
// 读取数组
int size = settings.beginReadArray("RecentFiles");
for (int i = 0; i < size; ++i) {settings.setArrayIndex(i);QString filePath = settings.value("filePath").toString();// 处理文件路径
}
settings.endArray();

5.2 检查键是否存在

if (settings.contains("User/Email")) {// 存在则读取QString email = settings.value("User/Email").toString();
}

5.3 删除配置项

// 删除单个键
settings.remove("User/Email");// 删除整个节
settings.remove("Network");

5.4 同步操作

通常无需手动调用,但在需要确保数据立即写入磁盘时使用:

settings.sync();

实例效果展示:

在这里插入图片描述
ini文件被创建
在这里插入图片描述
在这里插入图片描述
配置文件内容初始化文件内容一致。

实现功能:

实现在用户登录时,ini文件为空时的创建,如果ini文件存在,则根据用户的操作进行读取和写入。之前是使用数据库实现用户的登录和忘记密码操作的。但是有时候使用ini文件操作会更加简单,可以替换数据库的操作。

核心代码:

// 创建默认配置文件
void loginPage::createDefaultConfig()
{QSettings settings(filePathStr, QSettings::IniFormat);// 设置默认值settings.setValue("Login/lockPassword", false);settings.setValue("Login/autoLogin", false);settings.setValue("Login/password", "123456"); // 密码使用字符串格式存储settings.setValue("Login/hospitalName", "医院");qDebug() << "创建默认配置文件,初始密码: 123456";
}// 读取配置文件
void loginPage::readSettings()
{QSettings settings(filePathStr, QSettings::IniFormat);// 读取配置lockPassword = settings.value("Login/lockPassword", false).toBool();autoLoginFlag = settings.value("Login/autoLogin", false).toBool();passwordStr = settings.value("Login/password", "").toString();hospitalName = settings.value("Login/hospitalName", "").toString();// 更新UI状态ui->checkBoxLockPassword->setChecked(lockPassword);ui->checkBoxAutoLogin->setChecked(autoLoginFlag);// 如果记住密码,填充密码if (lockPassword) {ui->editPassword->setText(passwordStr);}
}// 写入配置文件
void loginPage::writeSettings()
{QSettings settings(filePathStr, QSettings::IniFormat);// 写入配置settings.setValue("Login/lockPassword", lockPassword);settings.setValue("Login/autoLogin", autoLoginFlag);settings.setValue("Login/password", passwordStr);settings.setValue("Login/hospitalName", hospitalName);
}

http://www.hkcw.cn/article/ebSFKTtwUP.shtml

相关文章

计算机网络之差错控制中的 CRC(循环冗余校验码)

文章目录 1 概述1.1 简介1.2 特点1.3 基本原则 2 实现步骤3 例题 1 概述 修改中&#xff0c;请稍等。。。 1.1 简介 CRC&#xff1a;Cyclic Redundancy Check&#xff08;循环冗余校验&#xff09;是计算机网络中常用的一种差错控制编码方法&#xff0c;用于检测数据传输或存…

VLC-QT 网页播放RTSP

先看效果图,代码在文章末尾,包含源码,vlc-qt完整的库 环境说明:VS 2017 QTQt5.13.0 MSVC2017 32位 将vlc_install 目录下的bin,include,lib里所有的东西分别放在qt目录下 bin -> C:\Qt\Qt5.13.0\5.13.0\msvc2017\bin include->C:\Qt\Qt5.13.0\5.13.0\msvc201…

塔能科技:为多行业工厂量身定制精准节能方案

在当今追求可持续发展的时代&#xff0c;工厂能耗精准节能成为众多企业关注的焦点。塔能科技凭借先进的技术和丰富的经验&#xff0c;服务于广泛的行业客户&#xff0c;其中55.5%来自世界500强和上市公司。针对不同行业工厂的特点和需求&#xff0c;塔能提供了一系列行之有效的…

Qt font + ToolTip + focusPolicy + styleSheet属性(5)

文章目录 font属性API接口直接在Qt Designer编辑图形化界面通过纯代码的方式修改文字属性 ToolTip属性API接口代码演示 focusPolicy属性概念理解API接口通过编辑图形化界面演示 styleSheet属性概念理解通过编辑图形化界面展示代码 图形化界面的方式展示&#xff08;夜间/日间模…

lwip_setsockopt设置地址复用出错(lwip默认不打开,lwip_bindu也会提示端口被占用)

/* 3. 设置地址复用 */ flags lwip_setsockopt(new_sockfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)); if (flags < 0) {NET_DEBUG_PRINT("[NET] SO_REUSEADDR failed: %s\n", strerror(errno));int opt_err errno;// 详细错误分析switch(opt_err) {c…

力扣面试150题--二叉树的右视图

Day 53 题目描述 思路 采取层序遍历&#xff0c;利用一个high的队列来保存每个节点的高度&#xff0c;highb和y记录上一个节点的高度和节点&#xff0c;在队列中&#xff0c;如果队列中顶部元素的高度大于上一个节点的高度&#xff0c;说明上一个节点就是上一层中最右边的元素…

Powerbuilder 连接达梦数据库(ODBC 和 JDBC)

一、ODBC PB只支持32位驱动&#xff0c;可以同时安装64和32位驱动&#xff0c;分别下载64和32位安装包安装 1、选择DMB ODBC DRIVER驱动 2、不描述&#xff0c;看图输信息即可 3、连接代码 SQLCA.DBMS "ODBC" SQLCA.AutoCommit False SQLCA.DBParm "Conne…

美化显示GDB调试的数据结构

笔者在前面的博文记一次pdf转Word的技术经历中有使用到mupdf库&#xff0c;该库是使用C语言写的一个操作PDF文件的库&#xff0c;同时提供了Python接口&#xff0c;Java接口和JavaScript接口。 在使用该库时&#xff0c;如果想要更高的性能&#xff0c;使用C语言接口是不二的选…

从融智学视角对决策态度进行定理级提炼,结合三标准数学建模

摘要&#xff1a;本文从融智学视角提出"决策态度定理"&#xff0c;构建了态度三要素&#xff08;化繁为简、迎难而上、乐在其中&#xff09;的数学模型。定理将人生轨迹表述为复平面路径积分&#xff1a;命运∫[态度⊗选择]dt&#xff0c;证明三要素协同作用可使决策…

秋招Day11 - JVM - 类加载机制

了解类的加载机制吗&#xff1f; JVM是运行Java字节码&#xff0c;也就是运行.class文件的虚拟机&#xff0c;JVM把.class文件中描述类的数据结构加载到内存中&#xff0c;并对数据进行校验&#xff0c;解析和初始化&#xff0c;最终转化为JVM可以使用的类型&#xff08;Klass…

纵览网丨病毒学领域的 AI 变局:机遇、隐忧与监管之路

纵览网&#xff08;www.zonglan.com&#xff09;人工智能AI正在各个领域高歌猛进&#xff0c;特别是在病毒学领域。最近在一项病毒学诊断的研究测试中&#xff0c;有着天才水平称号的OpenAI的o3模型&#xff0c;平均得分已经能够达到43.8%&#xff0c;而拥有学位的人类病毒博士…

从实验室到商用!铁电液晶如何改写显示技术格局?

一、显示技术瓶颈&#xff1a;传统液晶的「成长烦恼」 在 VR 游戏中&#xff0c;快速转动头部时画面拖影让人眩晕&#xff1b;高端投影在强光下画质模糊&#xff1b;医用显示器难以呈现 CT 影像的细微层次…… 这些困扰背后&#xff0c;是传统液晶技术在刷新率、分辨率和环境适…

电网中三相不平衡治理的全面解析

在现代电力系统中&#xff0c;三相平衡是保障电网高效、稳定运行的关键要素。然而&#xff0c;三相不平衡现象却时有发生&#xff0c;给电网的可靠供电和用电设备的安全运行带来诸多挑战。深入了解三相不平衡治理的相关知识&#xff0c;对于提升电网运行水平、保障电力供应质量…

2023年6级第一套长篇阅读

画名词概念&#xff0c;动词概念 多处定位原词加同义改写 画关键词&#xff0c;多处定位直接就可以选A了 没有定位的句子先比没匹配到的段落&#xff0c;再匹配长的段落先易后难

Opencv实用操作5 图像腐蚀膨胀

相关函数 腐蚀函数 img1_erosion cv2.erode(img1,kernel,iterations1) &#xff08;图片&#xff0c;卷积核&#xff0c;次数&#xff09; 膨胀函数 img_dilate cv2.dilate(img2,kernel1,iterations1) &#xff08;图片&#xff0c;卷积核&#xff0c;次数&#xff09;…

lua的注意事项2

总之&#xff0c;下面的返回值不是10&#xff0c;a&#xff0c;b 而且

vr中风--数据处理模型搭建与训练

# -*- coding: utf-8 -*- """ MUSED-I康复评估系统&#xff08;增强版&#xff09; 包含&#xff1a;多通道sEMG数据增强、混合模型架构、标准化处理 """ import numpy as np import pandas as pd from sklearn.model_selection import train_te…

【Oracle】DCL语言

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Oracle 文章目录 1. DCL概述1.1 什么是DCL&#xff1f;1.2 DCL的核心功能 2. 用户管理2.1 创建用户2.2 修改用户2.3 删除用户2.4 用户信息查询 3. 权限管理3.1 系统权限3.1.1 授予系统权限3.1.2 撤销系统权限 3.2 对象权限3.2.1…

使用Redisson实现分布式锁发现的【订阅超时】Subscribe timeout: (7500ms)

背景 使用 redisson 实现分布式锁&#xff0c;出现的异常&#xff1a; org.redisson.client.RedisTimeoutException: Subscribe timeout: (7500ms). Increase ‘subscriptionsPerConnection’ and/or ‘subscriptionConnectionPoolSize’ parameters 从异常信息读的出来一些东…

异步上传石墨文件进度条前端展示记录(采用Redis中String数据结构实现-苏东坡版本)

昔者&#xff0c;有客临门&#xff0c;亟需自石墨文库中撷取卷帙若干。此等文册&#xff0c;非止一卷&#xff0c;乃累牍连篇&#xff0c;亟需批量转置。然吾辈虑及用户体验&#xff0c;当效东坡"腹有诗书气自华"之雅意&#xff0c;使操作如行云流水&#xff0c;遂定…