QSettings模块

1.介绍

QSettings是Qt提供的,用于解决跨平台的持久化Settings类,该模块封装在core核心模块中。QSettings是对配置文件读写、修改等技术的抽象,使您能够以一种可移植的方式保存和恢复应用程序设置,它还支持自定义存储格式。

2.常见用法

2.1 读配置文件

/*使用文件路径初始化一个QSetting对象*/
QSettings setting(strFilePath,QSettings::IniFormat);

/*如果读取的配置中有中文,需要设置codec编码*/
setting.setCodec(QTextCodec::codecForName("utf-8"));//与INI文件的编码保持一致

/*直接获取key的值*/
QString strVaule = setting.vaule("key").toString();

2.2 写配置文件

/*使用文件路径初始化一个QSetting对象*/
QSettings setting(strFilePath,QSettings::IniFormat);

/*如果读取的配置中有中文,需要设置codec编码*/
setting.setCodec(QTextCodec::codecForName("utf-8"));//与INI文件的编码保持一致

/*设置value*/
setting.setVaule("key","hello");
setting.setVaule("num",123);
setting.setVaule("double",100.0);
setting.setVaule("flag",true);

2.3 读写注册表

qsettings简单的实现一个注册表读写操作,记录程序中需要保存的信息。使用qsettings声明对象之前,需要指明qsettings的组织名和应用名。即:

QCoreApplication::setOrganizationName("Digia");//指定组织名
QCoreApplication::setApplicationName("Qt");//指定应用名

指定组织名和应用名后就可以生成qsettings对象。qsettings保存数据可以保存到注册表中,也可以保存如ini文件中,在生成对象的时候需要指明数据存储格式。NativeFormat在win中式存储在系统的注册表中;IniFormat存储在ini文件中。

//生成qsettings对象,将数据写入注册表
//利用qsettings对象存储数据时,是存储一对数据,包括一个键值(key)和一个值(value),类似于map。
QSettings settings(QSettings::NativeFormat, QSettings::UserScope, QCoreApplication::organizationName(), QCoreApplication::applicationName());


写注册表

settings.setValue(key,value);
还有其他的方法:

settings.contains(key) //判断一个指定的键是否存在
settings.remove(key) //删除相关的键
settings.allKeys() //获取所有键
settings.clear() //删除所有键
QStringList file = settings.childKeys()//获取所有的value,存放在列表中

读注册表

QString FilePath = settings.value(key).toString();
有时候注册表中有分组,我们需要操作某个组,将settings跳到某个分组中:

settings.beginGroup("组名");//打开某组
settings.endGroup();//关闭某组

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值