博客
关于我
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 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>
Mysql 知识回顾总结-索引
查看>>
Mysql 笔记
查看>>
MySQL 精选 60 道面试题(含答案)
查看>>
mysql 索引
查看>>
MySQL 索引失效的 15 种场景!
查看>>
MySQL 索引深入解析及优化策略
查看>>
MySQL 索引的面试题总结
查看>>
mysql 索引类型以及创建
查看>>
MySQL 索引连环问题,你能答对几个?
查看>>
Mysql 索引问题集锦
查看>>
Mysql 纵表转换为横表
查看>>
mysql 编译安装 window篇
查看>>
mysql 网络目录_联机目录数据库
查看>>
MySQL 聚簇索引&&二级索引&&辅助索引
查看>>
Mysql 脏页 脏读 脏数据
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>