博客
关于我
QT读取JSON文件并解析
阅读量:610 次
发布时间:2019-03-13

本文共 1450 字,大约阅读时间需要 4 分钟。

(1)JSON文件(config.json)

{    "autor": "yudabo",    "staff":[        {"name":"于大博1"},        {"name":"于大博2"},        {"name":"于大博3"},        {"name":"于大博4"},        {"name":"于大博5"},        {"name":"于大博6"},        {"name":"于大博7"},        {"name":"于大博8"},        {"name":"于大博9"},        {"name":"于大博10"}    ],    "data": { "name": "yudabo" }}

(2)解析文件

QFile file("config.json");file.open(QIODevice: :ReadOnly | QIODevice: :Text);QString value = file.readAll();file.close();QJsonParseError parseJsonErr;QJsonDocument document = QJsonDocument: :fromJson(value.toUtf8(), &parseJsonErr);if (! (parseJsonErr.error == QJsonParseError: :NoError)) {    QMessageBox: :about(NULL, "提示", "配置文件错误!");    return;}QJsonObject jsonObject = document.object();/*    // autor字段    qDebug()<< "jsonObject[autor]==" << jsonObject["autor"].toString();*/// staff字段if (jsonObject.contains(QStringLiteral("staff"))) {    QJsonValue arrayValue = jsonObject.value(QStringLiteral("staff"));    if (arrayValue.isArray()) {        QJsonArray array = arrayValue.toArray();        for (int i = 0; i < array.size(); i++) {            QJsonValue nameArray = array.at(i);            QJsonObject key = nameArray.toObject();            qDebug() << "key[name]==" << key["name"].toString();        }    }}// data字段QJsonValue jsonDataValue = jsonObject.value(QStringLiteral("data"));QJsonObject jsonData = jsonDataValue.toObject();qDebug()<< "jsonData [name]==" << jsonData ["name"].toString();

 

转载地址:http://vbbaz.baihongyu.com/

你可能感兴趣的文章
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
查看>>
MySQL 快速创建千万级测试数据
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
MySql 手动执行主从备份
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>