qt json操作
json文件结构形式
{
"xiao1": [
{
"000100": {
"industryCode": "000100",
"industryName": "test"
}
},
{
"000101": {
"industryCode": "000100",
"industryName": "test"
}
},
{
"000103": {
"industryCode": "000100",
"industryName": "test"
}
}
],
"xiaogdsadg": [
{
"12321344": {
"industryCode": "12321344",
"industryName": "454555"
}
},
{
"54545445": {
"industryCode": "54545445",
"industryName": "454555"
}
},
{
"454454654": {
"industryCode": "454454654",
"industryName": "454555"
}
}
]
}
//判断指定项是否在json文件里
bool MainWindow:: isInJson(QString userName,QString rowId)
{
QString val;
QFile file;
file.setFileName("F:\\work\\qtProjects\\untitled11\\test123.json");
file.open(QIODevice::ReadOnly| QIODevice::Text);
val = file.readAll();
file.close();
QJsonDocument doc = QJsonDocument::fromJson(val.toUtf8());
QJsonObject objTop1 = doc.object();
QStringList keys = objTop1.keys();
//用户循环
for(int i = 0; i < keys.count();i++)
{
if(keys.at(i)!= userName)
continue;
QJsonArray arrayRows = objTop1.value(keys.at(i)).toArray();
//行循环
for(int j =0;j < arrayRows.count();j++)
{
QJsonObject objRow = arrayRows.at(j).toObject();
if(objRow.keys().at(0) == rowId)
{
return true;
}
}
}
return false;
}
//添加收藏
void MainWindow::addJson(QString userName, QString rowId)
{
if(!isInJson(userName,rowId))
{
bool hasUser = false;
QString val;
QFile file;
file.setFileName("F:\\work\\qtProjects\\untitled11\\test123.json");
file.open(QIODevice::ReadOnly| QIODevice::Text);
val = file.readAll();
file.close();
QJsonDocument doc = QJsonDocument::fromJson(val.toUtf8());
QJsonObject objTop1 = doc.object();
QStringList keys = objTop1.keys();
//用户循环
for(int i = 0; i < keys.count();i++)
{
if(keys.at(i) != userName)
continue;
QJsonArray arrayRows = objTop1.value(keys.at(i)).toArray();
QJsonObject addObj;
QJsonObject addObj1;
addObj1.insert("industryCode",rowId);
addObj1.insert("industryName","454555");
addObj.insert(rowId,addObj1);
arrayRows.append(addObj);
objTop1.insert(userName,arrayRows);
hasUser = true;
break;
}
//该用户还没有添加
if(!hasUser)
{
QJsonArray arrayRows;
QJsonObject addObj;
QJsonObject addObj1;
addObj1.insert("industryCode",rowId);
addObj1.insert("industryName","444545");
addObj.insert(rowId,addObj1);
arrayRows.append(addObj);
objTop1.insert(userName,arrayRows);
}
doc.setObject(objTop1);
file.setFileName("F:\\work\\qtProjects\\untitled11\\test123.json");
file.open(QIODevice::WriteOnly| QIODevice::Text);
file.write(doc.toJson());
file.close();
}
}
//取消收藏
void MainWindow::removeJson(QString userName, QString rowId)
{
if(isInJson(userName,rowId))
{
QString val;
QFile file;
file.setFileName("F:\\work\\qtProjects\\untitled11\\test123.json");
file.open(QIODevice::ReadOnly| QIODevice::Text);
val = file.readAll();
file.close();
QJsonDocument doc = QJsonDocument::fromJson(val.toUtf8());
QJsonObject objTop1 = doc.object();
QStringList keys = objTop1.keys();
//用户循环
for(int i = 0; i < keys.count();i++)
{
if(keys.at(i) != userName)
continue;
QJsonArray arrayRows = objTop1.value(keys.at(i)).toArray();
//行循环
for(int j =0;j < arrayRows.count();j++)
{
QJsonObject objRow = arrayRows.at(j).toObject();
if(objRow.keys().at(0) == rowId)
{
arrayRows.removeAt(j);
objTop1.insert(userName,arrayRows);
break;
}
}
doc.setObject(objTop1);
file.setFileName("F:\\work\\qtProjects\\untitled11\\test123.json");
file.open(QIODevice::WriteOnly| QIODevice::Text);
file.write(doc.toJson());
file.close();
break;
}
}
}
qt json操作的更多相关文章
- QT json数据的应用(cJSON)
json数据可保存小量的数据在本地的json文件中.QT有两种方式操作:(1).cJSON (2).QT的操作json数据的类. 应用:将监控预案数据保存在本地中. 1.首先根据预案结构创建一个jso ...
- Qt QAxObject操作excel文件过程总结(转):
正好同事问道Qt下操作excel. 转自:http://blog.csdn.net/a156392343/article/details/48092515 配制方面: 1.确保Excel软件在本地服务 ...
- Json操作(DynamicJson)
Json的简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了 ...
- ASP.NET 里的 JSON操作
最近项目中需要用到 JSON操作,google了一下 找到了几个比较好的操作方法.... 一 .使用 mircosoft 提供的 .NET Framework 自带的 json操作方法 1. 使用Ja ...
- 2.大约QT数据库操作,简单的数据库连接操作,增删改查数据库,QSqlTableModel和QTableView,事务性操作,大约QItemDelegate 代理
Linux下的qt安装,命令时:sudoapt-get install qt-sdk 安装mysql数据库,安装方法參考博客:http://blog.csdn.net/tototuzuoquan ...
- Qt之操作系统环境
来源:http://blog.sina.com.cn/s/blog_a6fb6cc90102uy9k.html Qt中操作系统环境,官方解释如下: QStringList QProcess::syst ...
- Newtonsoft.Json 操作 JSON 字符串
Newtonsoft.Json介绍 在做开发的时候,很多数据交换都是以json格式传输的.而使用Json的时候,我们很多时候会涉及到几个序列化对象的使用:DataContractJsonSeriali ...
- Asp.Net Core 2.0 项目实战(8)Core下缓存操作、序列化操作、JSON操作等Helper集合类
本文目录 1. 前沿 2.CacheHelper基于Microsoft.Extensions.Caching.Memory封装 3.XmlHelper快速操作xml文档 4.Serializatio ...
- JavaScript对json操作小记
JSON是一种轻量级的数据交换格式,同时,JSON是 JavaScript 原生格式,因此我们可以直接处理它不需要依赖任何工具包或者插件.因此,好多后台都会选择返回给前端这种非常友好的数据格式. 引子 ...
随机推荐
- windows上批量杀指定进程
Taskkill 结束一个或多个任务或进程.可以根据进程 ID 或图像名来结束进程. 语法 taskkill [/s Computer] [/u Domain\User [/p Password]]] ...
- 一次高IO下的GC分析之旅
一次高IO下的GC分析之旅 编码前线 关注 2018.12.21 00:06 字数 597 阅读 45评论 0喜欢 0 起因:收到GC STW报警 [监控系统]Total time for which ...
- java正则表达式详细总结
Java 提供了功能强大的正则表达式API,在java.util.regex 包下.本教程介绍如何使用正则表达式API. 正则表达式 一个正则表达式是一个用于文本搜索的文本模式.换句话说,在文本中搜索 ...
- project2016安装与破解
分步阅读 project2016发布增加了许多功能.Microsoft Office 2016 官方正式版发布!这是微软发布的全新办公软件套件,相比现有Office 2013的变化也不是很大,界面 ...
- spark 笔记 6: RDD
了解RDD之前,必读UCB的论文,个人认为这是最好的资料,没有之一. http://www.cs.berkeley.edu/~matei/papers/2012/nsdi_spark.pdf A Re ...
- Linux环境快速搭建elasticsearch6.5.4集群和Head插件
https://blog.csdn.net/boling_cavalry/article/details/86358716
- vue指令之v-cloak
vue指令之v-cloak 一起学 vue指令 v-cloak 指令可看作标签属性 某些情况下可能由于机器性能故障或者网络原因,导致传输有问题,那么浏览器无法成功解析数据,此时浏览器输出的内容就是纯 ...
- vue问题一:触发接口
//在script中先引用 import api from './../../api/index' //vue文件方法中 写 del(index, row) { let self=this; // 传 ...
- ORCAD导网表:遇"No_connect" property
问题: Orcad Capture中将No Connect标识放置到了原本应该放置连线的管脚上,不知道怎么删除. 虽然添加一根Wire可以掩盖该管脚上已经添加的No Connect标识,但是到处网表的 ...
- java删除文件夹或者文件
private static void deleteFile(File file) { if (file.exists()) { // 判断文件是否存在 if (file.isFile()) { // ...