QSettings继承于QObject,位于PyQt6.QtCore模块中,是PyQt中用来存储配置信息的常用工具。
QSettings的API基于QVariant,允许您以最小的工作量保存大多数基于值的类型,例如QString,QRect和QImage。
可通过配置将应用程序需要保存的参数数据保存到本地,如windows的注册表,macOS 和 iOS 上的属性列表文件,linux的ini文本文件等。
通过指定公司、软件信息初始化QSettings会将参数存储到系统默认的地方中,初始化方法如下:
@typing.overload
def __init__(self, organization: str, application: str = ..., parent: typing.Optional[QObject] = ...) -> None: ...
@typing.overload
def __init__(self, scope: 'QSettings.Scope', organization: str, application: str = ..., parent: typing.Optional[QObject] = ...) -> None: ...
@typing.overload
def __init__(self, format: 'QSettings.Format', scope: 'QSettings.Scope', organization: str, application: str = ..., parent: typing.Optional[QObject] = ...) -> None: ...
@typing.overload
def __init__(self, fileName: str, format: 'QSettings.Format', parent: typing.Optional[QObject] = ...) -> None: ...
@typing.overload
def __init__(self, scope: 'QSettings.Scope', parent: typing.Optional[QObject] = ...) -> None: ...
@typing.overload
def __init__(self, parent: typing.Optional[QObject] = ...) -> None: ...
不同的初始化有不同的配置信息存储位置,可供搜索的存储位置如下,软件会按顺序搜索:
1. 应用程序的用户特定位置;
2. 所属组织所有应用程序的用户特定位置;
3. app的系统范围位置;
4. 所属组织的的系统范围位置
假设组织为“MyORG”,应用程序名为“MyApp”:
构造函数 | 应用程序的用户特定位置 | 所属组织所有应用程序的用户特定位置 | app的系统范围位置 | 所属组织的的系统范围位置 |
---|---|---|---|---|
QSettings(“MyORG”,“MyApp”) | √ | √ | √ | √ |
QSettings(“MyORG”) | x | √ | √ | √ |
QSettings(QSettings.Scope.SystemScope, “MyORG”, “MyApp”) | x | x | √ | √ |
QSettings(QSettings.Scope.SystemScope, “MyORG”) | x | x | x | √ |
一般自动所有第一个找到的文件位置,其他位置的文件用作数据回退使用。根据系统不一样会存储到对用的注册表和配置文件夹路径。
通过指定文件路径以及设置文件格式,可以将配置信息存储到成配置文件,并且存储到指定目录下。
QSettings("config.ini", QSettings.Format.IniFormat)
此处传入两个参数,一个是文件路径,第二个是文件格式。
如果ini文件不存在时系统会自动创建该文件。
QSettings.Format格式
格式 | Unix | Windows |
---|---|---|
NativeFormat | .conf 文件 | 系统注册表 |
IniFormat | .ini 文件 | .ini 文件 |
注:
qsettings.setValue("name", self.txt_name.text())
传入两个参数,第一个参数为键值,第二个参数为要保存的值。
当键值存在时会替换该数值,键值不存在时会创建相依的值。
qsettings.value("name")
使用键值直接获取对应的数据,获取到的数据可再根据自己需要进行类型转换。
QSettings中存储数据可以使用“/”作为分组依据,键值中包含“\”和“/”字符最终都会前置转换为“/”。
而由于部分系统键值不区分大小写(如Windows),而部分系统键值区分大小写(如mac),故设置键值时尽量使用统一的键值,而且避免存在仅大小写不一致的键值。
使用“/”进行分组,即“/”前的是组别,之后的是名称,用于区分不同的单元和分组保存数据,实际使用,存在多分组的时候可以使用beginGroup()即endGroup()类做同组数据保存;
# App.config是一个QSettings类,我封装在App类中作为全局属性,方便调用
App.config.beginGroup("mainwindow")
App.config.setValue("name", self.txt_name.text())
print(self.mainview.txt_name.text())
App.config.setValue("password", self.txt_password.text())
print(self.mainview.txt_password.text())
App.config.sync() # 直接保存,若不调用则一段时间后自动保存。
App.config.endGroup()
结果如下:
111
这是密码
111
这是密码
# 添加分组后,键值会自动带上组别,并且以“/”划分
['mainwindow/name', 'mainwindow/password', 'name', 'password', 'size']
若多次使用分组管理,则会自行添加多个分组。
# 多次使用分组管理
App.config.beginGroup("mainwindow")
App.config.beginGroup("login")
App.config.setValue("name", self.txt_name.text())
App.config.setValue("password", self.txt_password.text())
App.config.sync() # 直接保存,若不调用则一段时间后自动保存。
App.config.endGroup()
App.config.endGroup()
结果:
['mainwindow/login/name', 'mainwindow/login/password', 'mainwindow/name', 'mainwindow/password', 'name', 'password', 'size']
App.config.allKeys()
['mainwindow/login/name', 'mainwindow/login/password', 'mainwindow/name', 'mainwindow/password', 'name', 'password', 'size']
App.config.childGroups()
childGroups :
['mainwindow']
App.config.childKeys()
childKeys :
['name', 'password', 'size']
App.config.clear()
print("clear : ")
print(App.config.allKeys())
clear :
[]
此操作会删除数据,建议谨慎操作,一般使用remove方法代替,用于移除指定的分组或键值数据。
remove(Union[QByteArray, str])
App.config.remove("mainwindow")
print("allKeys : ")
print(App.config.allKeys())
allKeys :
['name', 'password']
注:
contains(Union[QByteArray, str]) → bool
键值查询时直接查询,若要查询分组,需要先行调用beginGroup()函数,然后在进行查询。
status() → Status
状态 | 值 | 说明 |
---|---|---|
AccessError | 1 | 访问错误(如尝试写入只读文件) |
FormatError | 2 | 格式错误(如加载错误的ini文件) |
NoError | 0 | 未发生错误 |