博客
关于我
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 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>
mysql 锁机制 mvcc_Mysql性能优化-事务、锁和MVCC
查看>>
MySQL 错误
查看>>
mysql 随机数 rand使用
查看>>
MySQL 面试题汇总
查看>>
MySQL 面试,必须掌握的 8 大核心点
查看>>
MySQL 高可用性之keepalived+mysql双主
查看>>
MySQL 高性能优化规范建议
查看>>
mysql 默认事务隔离级别下锁分析
查看>>
Mysql--逻辑架构
查看>>
MySql-2019-4-21-复习
查看>>
mysql-5.6.17-win32免安装版配置
查看>>
mysql-5.7.18安装
查看>>
MySQL-Buffer的应用
查看>>
mysql-cluster 安装篇(1)---简介
查看>>
mysql-connector-java.jar乱码,最新版mysql-connector-java-8.0.15.jar,如何愉快的进行JDBC操作...
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-EXPLAIN
查看>>
MySQL-Explain的详解
查看>>