欢迎转载,请注明出处:https://blog.csdn.net/qq_39453936?spm=1010.2135.3001.5343
原文链接: https://blog.csdn.net/qq_39453936/article/details/120758754
QSetting
QSettings介绍
用户通常希望应用程序在会话中记住其设置(窗口大小和位置、选项等)。这些信息通常存储在Windows上的系统注册表中,以及macOS和iOS上的属性列表文件中。在Unix系统上,在没有标准的情况下,许多应用程序(包括KDE应用程序)使用INI文本文件。
QSettings使用户可以保存应用程序设置,并且支持用户自定义存储格式。QSetings API基于QVariant,因而你可以存储却大部分类型的数据。如果你需要一个非持久性的存储,推荐使用QMap<QString, QVariant>.
基本使用
- 创建QSettings对象
创建QSettings对象时,必须传递公司或组织的名称以及应用程序的名称。例如,如果您的产品名为Star Runner,而您的公司名为MySoft,那么您将按照以下方式构造QSettings对象:
QSettings对象可以在堆栈上或堆上创建(即使用new)。构造和销毁QSettings对象的速度非常快。如果在应用程序中使用多个位置的QSettings,可能需要使用:QSettings settings("MySoft", "Star Runner");
QCoreApplication::setOrganizationName()指定组织名称,QCoreApplication::setApplicationName()指定应用程序名称,然后使用默认QSettings构造函数:QCoreApplication::setOrganizationName("MySoft"); QCoreApplication::setOrganizationDomain("mysoft.com"); QCoreApplication::setApplicationName("Star Runner"); ... QSettings settings;
- 写入数据
QSettings存储设置。每个设置由一个指定QString类型的名称key和一个存储与键关联的数据的QVariant组成。settings.setValue("editor/wrapMargin", 68); ```
- 读取数据
如果没有指定名称的设置,QSettings将返回空QVariant(可以转换为整数0)。通过将第二个参数传递给value(),可以指定另一个默认值:int margin = settings.value("editor/wrapMargin").toInt(); int margin = settings.value("editor/wrapMargin", 80).toInt();
- QVariant and GUI Types
由于QVariant不能提供到QColor、QImage和QPixmap等数据类型的转换函数,这些数据类型是Qt GUI的一部分,可以使用QVariant::value()或qVariantValue()模板函数。例如://写 QSettings settings("MySoft", "Star Runner"); QColor color = palette().background().color(); settings.setValue("DataPump/bgcolor", color); //读 QSettings settings("MySoft", "Star Runner"); QColor color = settings.value("DataPump/bgcolor").value<QColor>();
- 操作注册表
QSettings settings(QSettings::NativeFormat, QSettings::UserScope, QCoreApplication::organizationName(), QCoreApplication::applicationName());
- 操作配置文件
QSettings settings(QSettings::IniFormat, QSettings::UserScope, QCoreApplication::organizationName(), QCoreApplication::applicationName());
- 操作指定文件
QSettings::QSettings(const QString &fileName, QSettings::Format format, QObject *parent = nullptr)
分组读写
- 分组存储
QSettings settings(QSettings::IniFormat, QSettings::UserScope, QCoreApplication::organizationName(), QCoreApplication::applicationName()); settings.beginGroup("Setting"); settings.setValue("Name", "Qt Creator"); settings.setValue("Version", 5); settings.endGroup(); settings.beginGroup("User"); settings.setValue("UserName", "WangL"); settings.setValue("Password", "123456"); settings.endGroup();
- 分组读取
settings.beginGroup("Setting"); QString strName = settings.value("Name").toString(); int nVersion = settings.value("Version").toInt(); settings.endGroup(); //Name:Qt Creator Version:5 settings.beginGroup("User"); QString strUserName = settings.value("UserName").toString(); QString strPassword = settings.value("Password").toString(); settings.endGroup(); //UserName:WangL Password:123456
其他
-
判断key是否存在: bool QSettings::contains(const QString &key) const
-
移除某项:void QSettings::remove(const QString &key),如果key为空字符串,在当前group()的所有键将被删除。
-
清空所有键 void QSettings::clear()
-
得到所有键:QStringList QSettings::allKeys()
参考文章:https://blog.csdn.net/liang19890820/article/details/50518187
小白发文,欢迎指正