Qt - QSetting的使用

欢迎转载,请注明出处:https://blog.csdn.net/qq_39453936?spm=1010.2135.3001.5343
原文链接: https://blog.csdn.net/qq_39453936/article/details/120758754

QSetting

  • QSettings介绍
  • 基本使用
  • 分组读写
  • 其他


QSettings介绍

用户通常希望应用程序在会话中记住其设置(窗口大小和位置、选项等)。这些信息通常存储在Windows上的系统注册表中,以及macOS和iOS上的属性列表文件中。在Unix系统上,在没有标准的情况下,许多应用程序(包括KDE应用程序)使用INI文本文件。
QSettings使用户可以保存应用程序设置,并且支持用户自定义存储格式。QSetings API基于QVariant,因而你可以存储却大部分类型的数据。如果你需要一个非持久性的存储,推荐使用QMap.
Qt - QSetting的使用_第1张图片


基本使用

  • 创建QSettings对象
    创建QSettings对象时,必须传递公司或组织的名称以及应用程序的名称。例如,如果您的产品名为Star Runner,而您的公司名为MySoft,那么您将按照以下方式构造QSettings对象:
    QSettings settings("MySoft", "Star Runner");
    
    QSettings对象可以在堆栈上或堆上创建(即使用new)。构造和销毁QSettings对象的速度非常快。如果在应用程序中使用多个位置的QSettings,可能需要使用:
    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
小白发文,欢迎指正

你可能感兴趣的:(Qt,qt,c++,交互,ui,visual,studio)