json数据解析
目录
一、读数据
1、简单对象读取
2、数组读取
3、对象读取
二、写数据
1、简单生成JSON
2、对象数组JSON
3、嵌套对象
三、一个综合例子
1、读JSON
2、写JSON
一、读数据
1、简单对象读取
{"app": "xnwVideo","src": "C:\\build-video\\Output","dest": "C:\\build-video\\1.0.32","version": "1.0.32","build": 32,"note": "布局json读取","act": "All"
}
CBinBuf buf;buf.ReadFile("jsonInfo.json");CJsonObj json(buf);CBinBuf app, src, des, note, build, fullVersion, act;json.getString("app", app);json.getString("src", src);json.getString("dest", des);json.getString("note", note);json.getString("build", build);json.getString("version", fullVersion);json.getString("act", act);
2、数组读取
文件如下:
[{"id": "Integrated Webcam:\\\\?\\usb#22vid_0c45&pid_671f&mi_00#226&8c5ffc6&0&0000#22{65e8773d-8f56-11d0-a3b9-00a0c9223196}\\global","res": "1280x720"},{"id": "XSplit VCam:\\\\?\\root#22image#220000#22{65e8773d-8f56-11d0-a3b9-00a0c9223196}\\global","res": "1280x720"},{"id": "YY开播:","res": "1280x720"},{"id": "c922 Pro Stream Webcam:\\\\?\\usb#22vid_046d&pid_085c&mi_00#227&1e59b99a&0&0000#22{65e8773d-8f56-11d0-a3b9-00a0c9223196}\\global","res": "1920x1080"}
]
读取方式:
std::map<std::string, std::string > camIDResMap_;CBinBuf buf;buf.ReadFile(jsonPath.c_str());CJsonObj json(buf);for (int i = 0; i < json.get_arry_size(); ++i){CJsonObj * pJson = json.get_arry_at(i);string id, res;pJson->getString("id", id);pJson->getString("res", res);camIDResMap_[id] = res;}
类似的还有:
for (int i = 0; i < class_info->get_arry_size(); ++i) {CJsonObj* pJson = class_info->get_arry_at(i);std::string courseID, chapterID, qID, chapterName, startTime, endTime, className, imgUrl;int nStatus;pJson->getString("course.id", courseID);pJson->getString("id", chapterID); pJson->getString("class.qid", qID);pJson->getString("name", chapterName);pJson->getString("start_time", startTime);pJson->getString("end_time", endTime);nStatus = pJson->getInt("live_status");/*CJsonObj* pCourseJson = pJson->getObj("course", err);pCourseJson->getString("name", className); pCourseJson->getString("cover_url", imgUrl);*/pJson->getString("course.name", className);pJson->getString("course.cover_url", imgUrl);//timelong iStartTime = atoi(startTime.c_str());long iEndTime = atoi(endTime.c_str());std::string timeStr = GetTimeStr(iStartTime, iEndTime);//添加列表中ui::ListContainerElement* pItem = dynamic_cast<ui::ListContainerElement*>(ui::GlobalManager::CreateBoxWithCache(L"myClass/myclass_list_item.xml"));myClass_list->Add(pItem);if (curCourseId==courseID&&curChapterId==chapterID){m_pCurItem = pItem; //刷新后,重置当前节点bCurItemReseted = TRUE;}//详细信息设置SetText(pItem, L"courseName", nbase::UTF8ToUTF16(className).c_str());SetText(pItem, L"chapterName", nbase::UTF8ToUTF16(chapterName).c_str());SetText(pItem, L"time", MyString::stows(timeStr).c_str());//asic->utfSetDataID(pItem, L"time", startTime);SetDataID(pItem, L"courseName", endTime); //此项利用上,保存这节课结束时间std::wstring statusStr;switch (nStatus){case 0:statusStr = L"未开始";break;case 1:statusStr = L"正在直播";break;case 4:statusStr = L"正在直播";break;case 2:statusStr = L"已结束";break;case 3:statusStr = L"缺课";break;}SetText(pItem, L"live_status", statusStr);ui::Control* pClassPhoto = (ui::Control*)pItem->FindSubControl(L"classPhoto");if (pClassPhoto){//根据Json 传来的照片网址,与本地地址映射//之所以加?做分隔符,是因为文件名不能包含?std::wstring url = nbase::UTF8ToUTF16(imgUrl);//此段代码用于线程下载时使用std::wstring IndexStr = std::to_wstring(i);std::wstring pathTemp = MyString::format(L"tmp\\classPhoto%s.png", IndexStr.c_str());std::wstring localPath = IndexStr + L"?" + localFoldPathW + pathTemp;std::wstring remotePath = IndexStr + L"|" + url;AddMapItem(remotePath, localPath);///xnw_http_download(imgUrl.c_str(), GetHWND(), i);}ui::Button* pEnterLSRoomBtn = (ui::Button*)pItem->FindSubControl(L"enterLiveRoom_Btn"); pEnterLSRoomBtn->AttachClick(nbase::Bind(&MyClassForm::EnterRoom, this, std::placeholders::_1));pItem->SetUTF8DataID(courseID); //设置item标识为章节IDpEnterLSRoomBtn->SetUTF8DataID(chapterID);pClassPhoto->SetUTF8DataID(qID);}if (!bCurItemReseted){m_pCurItem = NULL;}}
3、对象读取
{"list": [{"name": "亮度92","props": {"BacklightCompensation": 1,"Brightness": 92,"ColorEnable": 16,"Contrast": 91,"Gain": 16,"Gamma": 62,"Hue": 91,"Saturation": 255,"Sharpness": 62,"WhiteBalance": -1},"control": {"Exposure": -4,"Focus": 0,"Iris": 100,"Pan": 0,"Roll": 0,"Tilt": 0,"Zoom": 100}},{"name": "高亮170","props": {"BacklightCompensation": 0,"Brightness": 170,"ColorEnable": 3,"Contrast": 128,"Gain": 3,"Gamma": 188,"Hue": 128,"Saturation": 128,"Sharpness": 188,"WhiteBalance": -1},"control": {"Exposure": -4,"Focus": 0,"Iris": 100,"Pan": 0,"Roll": 0,"Tilt": 0,"Zoom": 100}}]
}
对象的值又是数组的情况下,读取方式
CJsonObj ampJson(jsonS.c_str());{int nCount = 0;int err;CJsonObj* arry = ampJson.getObj("list", err);if (arry && arry->isarray()) {nCount = arry->get_arry_size();std::string s;std::wstring name;for (int i = 0; i < arry->get_arry_size(); ++i) {CJsonObj* pJson = arry->get_arry_at(i);pJson->getString("name", s);name = to_wchar_t(s);g_SelfCamAmpPropNameVec.push_back(name);}}}
类似的还有
CBinBuf bfJson;if(bfJson.ReadFile(m_file)) {load(bfJson, 0);
void load(const char* jstr, int merge) {uint32_t now = (uint32_t)time(0);CJsonObj js(jstr);m_tm = js.getInt("tm", 0);m_tmReport = js.getInt("tmReport", now);int err;CJsonObj* pList = js.getObj("list", err);if(pList) {std::vector<CDNINFO> v, vOld;if(merge) {for(int i=0; i<m_vCdn.size(); ++i) vOld.push_back(m_vCdn[i]);}m_vCdn.clear();for(int i=0; i<pList->get_arry_size(); ++i) {CDNINFO c;CJsonObj* pItem = pList->get_arry_at(i);c.from(pItem);add(c, merge, vOld);}}}
二、写数据
1、简单生成JSON
CJsonString bf("{");bf.append_item("file", szUtf8);bf.append_item("url", cbitem->url);bf.append_item("wparam",(uint64_t)cbitem->wParam);bf.close("}");
又如,
void MakeDefaultJson(CJsonString &jsonStr){jsonStr.append_item("is_beauty_on", 1); //美颜全局开关,0为关,1为开,默认为1//滤镜 jsonStr.append_item("filter_level", 0); //0-10 ->[0,1] 取值范围 0.0-1.0,0.0为无效果,1.0为最大效果,默认值1.0jsonStr.append_item("filter_name", "origin");//美白jsonStr.append_item("color_level", 2); //0-20 [0,2.0] 取值范围 0.0-2.0,0.0为无效果,2.0为最大效果,默认值0.2//红润jsonStr.append_item("red_level", 5); //0-20 [0,2.0] 取值范围 0.0-2.0,0.0为无效果,2.0为最大效果,默认值0.5//磨皮程度jsonStr.append_item("blur_level", 60); //[0,6.0] 磨皮程度,取值范围0.0-6.0,默认6.0jsonStr.append_item("skin_detect", 0); //肤色检测开关,0为关,1为开 默认0jsonStr.append_item("nonskin_blur_scale", 0); //0-10 [0,1]肤色检测之后非肤色区域的融合程度,取值范围0.0-1.0,默认0.0jsonStr.append_item("heavy_blur", 0); //朦胧磨皮开关,0为清晰磨皮,1为朦胧磨皮jsonStr.append_item("blur_type", 2); //此参数优先级比heavy_blur低,在使用时要将heavy_blur设为0,0 清晰磨皮 1 朦胧磨皮 2精细磨皮jsonStr.append_item("blur_use_mask", 0); //ios端默认为1,其他端默认为0。1为开启基于人脸的磨皮mask,0为不使用mask正常磨皮。只在blur_type为2时生效。jsonStr.append_item("sharpen", 2); //锐化程度,取值范围0.0-1.0,默认0.2jsonStr.close();//jsonStr.WriteFile("jsonInfoRes.json");
}
2、对象数组JSON
CJsonString jsonStr;jsonStr.begin("[");for (auto &it : camIDResMap){CJsonString camJson;camJson.begin("{");camJson.append_item("id", it.first.c_str());camJson.append_item("res", it.second.c_str());camJson.close("}");jsonStr.append_obj(camJson);}jsonStr.close("]");jsonStr.WriteFile(m_camjsonPath);
3、嵌套对象
{"list": [{"name": "亮度92","props": {"BacklightCompensation": 1,"Brightness": 92},"control": {"Exposure": -4,"Zoom": 100}},{"name": "高亮170","props": {"BacklightCompensation": 0,"WhiteBalance": -1},"control": {"Exposure": -4,"Zoom": 100}}]
}
CJsonString jsonStr;jsonStr.begin("[");int nCount = 0;for (auto &it : selfCamPros_){std::map<std::string, int> &Map = it.second;std::wstring nameW = it.first;std::map<std::string, int> &ctlMap = selfCamControls_[nameW];std::string name = to_string(nameW);CJsonString camAllJson;camAllJson.begin("{");camAllJson.append_item("name", name.c_str());CJsonString ampJsonObj;ampJsonObj.begin("{");auto oneAmpIt = ampMap.begin();while (oneAmpIt != ampMap.end()){ampJsonObj.append_item(oneAmpIt->first.c_str(), oneAmpIt->second);oneAmpIt++;}ampJsonObj.close("}");camAllJson.append_obj("props", ampJsonObj);CJsonString ctlJsonObj;ctlJsonObj.begin("{");auto oneCtlIt = ctlMap.begin();while (oneCtlIt != ctlMap.end()){ctlJsonObj.append_item(oneCtlIt->first.c_str(), oneCtlIt->second);oneCtlIt++;}ctlJsonObj.close("}");camAllJson.append_obj("control", ctlJsonObj);camAllJson.close("}");jsonStr.append_obj(camAllJson);}jsonStr.close("]");CJsonString listObjJsonS;listObjJsonS.begin("{");listObjJsonS.append_obj("list", jsonStr);listObjJsonS.close("}");listObjJsonS.WriteFile(sysJsonPath);
又如,
CJsonString js, list;js.append_item_u32("tm", m_tm);js.append_item_u32("tmReport", m_tmReport);format_json(list);js.append_obj("list", list);js.close("}");js.WriteFile(m_file);
void format_json(CJsonString& js) {js.begin("[");size_t n = m_vCdn.size();for(int i=0; i<n; ++i) {CDNINFO& c = m_vCdn[i];CJsonString cdn;c.format(cdn);js.append_obj(cdn);}js.close("]");}
又如,
CJsonString js,list;list.begin("[");for (auto it = nameVec.begin(); it != nameVec.end(); it++){CJsonString jsObj;std::wstring name = *it;if (name == L"类别")continue;std::string name8 = nbase::UTF16ToUTF8(name);jsObj.begin("{");jsObj.append_item("name", name8.c_str());jsObj.close("}");list.append_obj(jsObj);}list.close("]");js.append_obj("list", list);js.close("}");js.WriteFile("d:\\name.json");
三、一个综合例子
{"nameArr": [{"account": "张三"},{"account": "王五"},{"account": "李四"}],"phoneArr": [{"account": "1800000"}]
}
1、读JSON
std::set<std::wstring> acountSet_;std::set<std::wstring> acountPhoneSet_;void ReadAcountSet()
{std::string path = GetXnwAccountJsonPath();CBinBuf buf;if (buf.Read(path.c_str())){CJsonObj json(buf);int err;CJsonObj* arry = json.getObj("nameArr", err);if (arry && arry->isarray()){for (int i = 0; i < arry->get_arry_size(); ++i){CJsonObj * pJson = arry->get_arry_at(i);std::string name;pJson->getString("account", name);if (!name.empty()){std::wstring namew = nbase::UTF8ToUTF16(name);acountSet_.insert(namew);}}}arry = json.getObj("phoneArr", err);if (arry && arry->isarray()){for (int i = 0; i < arry->get_arry_size(); ++i){CJsonObj * pJson = arry->get_arry_at(i);std::string name;pJson->getString("account", name);std::wstring namew = nbase::UTF8ToUTF16(name);acountPhoneSet_.insert(namew);}}}}
2、写JSON
void SaveAcountSet(){std::string path = GetXnwAccountJsonPath();CJsonString listJsonStr;listJsonStr.begin("{");CJsonString jsonStr;jsonStr.begin("[");for (auto &it : acountSet_){std::string name = nbase::UTF16ToUTF8(it);CJsonString json;json.begin("{");json.append_item("account", name.c_str());json.close("}");jsonStr.append_obj(json);}jsonStr.close("]");listJsonStr.append_obj("nameArr", jsonStr);CJsonString jsonStr2;jsonStr2.begin("[");for (auto &it : acountPhoneSet_){std::string name = nbase::UTF16ToUTF8(it);CJsonString json;json.begin("{");json.append_item("account", name.c_str());json.close("}");jsonStr2.append_obj(json);}jsonStr2.close("]");listJsonStr.append_obj("phoneArr", jsonStr2);listJsonStr.close("}");listJsonStr.WriteFile(path.c_str());
}
相关文章:
json数据解析
目录 一、读数据 1、简单对象读取 2、数组读取 3、对象读取 二、写数据 1、简单生成JSON 2、对象数组JSON 3、嵌套对象 三、一个综合例子 1、读JSON 2、写JSON 一、读数据 1、简单对象读取 {"app": "xnwVideo","src": "C:\\buil…...
Verilog零基础入门(边看边练与测试仿真)-状态机-笔记(7-10讲)
文章目录 第七讲第八讲第九讲第十讲 第七讲 1、最简单的状态机-三角波发生器 1、两种状态的代码: //最简单的状态机,三角波发生器; timescale 1ns/10ps module tri_gen(clk,res,d_out); input clk; input res; o…...
【Hadoop】HDFS API 操作大全
🍁 博主 "开着拖拉机回家"带您 Go to New World.✨🍁 🦄 个人主页——🎐开着拖拉机回家_Linux,大数据运维-CSDN博客 🎐✨🍁 🪁🍁 希望本文能够给您带来一定的帮助…...
Webpack打包图片
一、在js文件中引入图片 二、在package.config.js中配置加载器 module.exports {mode: "production", // 设置打包的模式:production生产模式 development开发模式module: {rules: [// 配置img加载器{test: /\.(jpg|png|gif)$/i,type:"asset/resou…...
DipC 构建基因组 3D 结构(学习笔记)
背景 本文主要记录了 DipC 数据的复现过程、学习笔记及注意事项。 目录 下载 SRA 数据使用 SRA Toolkit 转换 SRA 数据为 Fastq 格式使用 bwa 比对测序数据使用 Hickit 计算样本的基因组 3D 结构使用散点图展示 3D 结构计算 3D 结构重复模拟的稳定性其他 步骤 1. 下载 SRA…...
Qt中音频的使用
对于音频我们在使用的过程中一般是录制音频、播放音频。针对这两个需求介绍Qt中音频的使用。 Qt中音频的录制 步骤: 1、获取系统中的音频设备。 2、创建QAudioRecorder对象,指定使用的音频设备,通过QAudioRecorder的setAudioInput函数设置…...
[centos]centos7源码编译cmake报错Could NOT find OpenSSL
测试环境: centos7.9 cmake3.25.0 ./bootstrap以后报错如下: Could NOT find OpenSSL, try to set the path to OpenSSL root folder in the system variable OPENSSL_ROOT_DIR (missing: OPENSSL_CRYPTO_LIBRARY OPENSSL_INCLUDE_DIR) CMake Error …...
vue若依前端项目搭建
1.项目搭建 首先进入到你需要创建的项目目录下面,然后输入命令vue create .创建项目 接下来选择手动搭建,然后把下面图片中的内容选上 再然后继续配置一些参数信息 接下来运行npm run serve项目就启动起来了 2.配置登录界面文件 首先修改src/router…...
基于win32实现TB登陆滑动验证
这里写目录标题 滑动验证触发条件:失败条件:解决方法:清除cooKie 滑动验证方式一:win32 api获取窗口句柄,选择固定位置 成功率高方式二: 原自动化滑动,成功率中 案例 先谈理论,淘宝 taobao.com …...
vue学习-07todoList案例与浏览器本地存储
TodoList Todo List(任务列表)是一个简单的Web应用程序示例,用于管理任务、代办事项或清单。Vue.js 是一个非常适合构建这种类型应用程序的框架,因为它提供了数据绑定、组件化、响应式和轻松管理用户界面的能力。 以下是一个基本…...
探索智能应用的基石:多模态大模型赋能文档图像处理
目录 0 写在前面1 文档图像分析新重点2 token荒:电子文档助力大模型3 大模型赋能智能文档分析4 文档图像大模型应用可能性4.1 专有大模型4.2 多模态模型4.3 设计思路 总结 0 写在前面 中国智能产业高峰论坛(CIIS2023)旨在为政企研学各界学者专家提供同台交流的机会…...
自动化发布npm包小记
1.注册npm账号 打开npm官网,并注册自己的npm账号 2.申请AccessToken 1.登录npm官网,登录成功后,点开右上角头像,并点击Access Tokens选项 2.点开Generate New Token下拉框,点击Classic Token(和Granular Access To…...
详解机器视觉性能指标相关概念——混淆矩阵、IoU、ROC曲线、mAP等
目录 0. 前言 1. 图像分类性能指标 1.1 混淆矩阵(Confusion Matrix) 1.2 准确率(Precision) 1.3 召回率(Recall) 1.4 F1值(F1 score) 1.5 ROC曲线(接收者工作特征曲线,Receiver Operating Characteristic curve) 1.6 mAP(mean Average Precision) 2. 图像分…...
想要精通算法和SQL的成长之路 - 预测赢家
想要精通算法和SQL的成长之路 - 预测赢家 前言一. 预测赢家二. 石子游戏(预测赢家的进阶版)2.1 博弈论 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 预测赢家 原题链接 主要思路: 我们定义dp[i][j]:在区间 [i, j] 之间先…...
高精度PWM脉宽调制信号转模拟信号隔离变送器1Hz~10KHz转0-5V/0-10V/1-5V/0-10mA/0-20mA/4-20mA
主要特性: >>精度等级:0.1级。产品出厂前已检验校正,用户可以直接使用 >>辅助电源:8-32V 宽范围供电 >>PWM脉宽调制信号输入: 1Hz~10KHz >>输出标准信号:0-5V/0-10V/1-5V,0-10mA/0-20mA/4-20mA等&…...
Vue路由和Node.js环境搭建
文章目录 一、vue路由1.1 简介1.2 SPA1.3 实例 二、Node.js环境搭建2.1 Node.js简介2.2 npm2.3 环境搭建2.3.1 下载解压2.3.2 配置环境变量2.3.3 配置npm全局模块路径和cache默认安装位置2.3.4 修改npm镜像提高下载速度 2.4 运行项目 一、vue路由 1.1 简介 Vue 路由是 Vue.js…...
【Vue】使用vue-cli搭建SPA项目的路由,嵌套路由
一、SPA项目的构建 1、前期准备 我们的前期的准备是搭建好Node.js,测试: node -v npm -v2、利用Vue-cli来构建spa项目 2.1、什么是Vue-cli Vue CLI 是一个基于 Vue.js 的官方脚手架工具,用于自动生成vue.jswebpack的项目模板,它可以帮助开发者…...
Excel 通过条件格式自动添加边框
每录入一次数据就需要手动添加一次边框,非常麻烦,这不是我们想要的。 那么有没有办法,在我们录入数据后,自动帮我们加上边框呢? 选中要自动添加边框的列,然后按箭头流程操作 ↓ ↓ ↓ ↓...
mysql 备份和还原 mysqldump
因window系统为例 在mysql安装目录中的bin目录下 cmd 备份 备份一个数据库 mysqldump -uroot -h hostname -p 数据库名 > 备份的文件名.sql 备份部分表 mysqldump -uroot -h hostname -p 数据库名 [表 [表2…]] > 备份的文件名.sql ## 多个表 空格隔开,中间…...
ELK日志分析系统+ELFK(Filebeat)
本章结构: 1、ELK日志分析系统简介 2、Elasticsearch介绍(简称ES) 3、Logstash介绍 4、Kibana介绍 5、实验,ELK部署 一、ELK日志分析系统简介 ELK平台是一套完整的日志集中处理解决方案,将 ElasticSearch、Logst…...
OpenClaw自动化测试:Qwen3.5-9B在API接口校验中的实战应用
OpenClaw自动化测试:Qwen3.5-9B在API接口校验中的实战应用 1. 为什么选择OpenClaw做接口自动化测试 去年接手一个个人项目时,我遇到了接口测试的痛点:每次后端更新都要手动验证几十个API,不仅耗时还容易遗漏边缘case。尝试过Pos…...
Anthropic调整Claude使用限制以缓解高峰时段需求压力
Anthropic公司周三调整了Claude客户的使用限制策略,在高峰需求时段降低服务功率,以平衡用户需求与其服务交付能力。Anthropic技术团队成员Thariq Shihipar在社交媒体上发布消息称:"为了管理Claude日益增长的需求,我们正在调整…...
MicroOS:Arduino轻量级任务调度内核详解
1. MicroOS:面向Arduino的轻量级任务管理内核概述MicroOS是一个专为Arduino平台设计的极简型实时任务管理器,其核心定位并非替代FreeRTOS或Zephyr等完整RTOS,而是填补Arduino原生loop()单线程模型在多任务调度、精确定时与事件解耦方面的空白…...
别再让电费偷偷溜走!用智能时间开关改造家里的热水器和空调(附保姆级选购指南)
别再让电费偷偷溜走!用智能时间开关改造家里的热水器和空调(附保姆级选购指南) 每到月底收到电费账单时,那种"钱不知不觉就溜走"的感觉总是让人心疼。特别是热水器和空调这两大"电老虎",它们往往…...
日志分散难管理?用Visual Syslog Server实现企业级日志集中监控的5个实战方案
日志分散难管理?用Visual Syslog Server实现企业级日志集中监控的5个实战方案 【免费下载链接】visualsyslog Syslog Server for Windows with a graphical user interface 项目地址: https://gitcode.com/gh_mirrors/vi/visualsyslog 痛点诊断:日…...
如何5分钟构建专业级黑苹果EFI?OpCore Simplify让复杂配置一键搞定
如何5分钟构建专业级黑苹果EFI?OpCore Simplify让复杂配置一键搞定 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 副标题:告别…...
ClawdBot实战教程:零基础搭建个人AI助手的完整流程
ClawdBot实战教程:零基础搭建个人AI助手的完整流程 1. ClawdBot简介:你的本地AI助手 ClawdBot是一个可以在个人设备上运行的AI助手解决方案,基于vLLM提供后端模型能力。与常见的云端AI服务不同,它完全运行在本地环境中ÿ…...
uniApp离线打包实战避坑指南
1. 离线打包前的环境准备 第一次接触uniApp离线打包时,我踩过的第一个坑就是环境配置。当时以为只要安装了Android Studio就能万事大吉,结果编译时各种报错接踵而至。后来才发现,离线打包对开发环境的版本匹配要求极为严格,差一个…...
告别手打公式!用SimpleTex截图转LaTeX+Axmath微调+Typora排版的保姆级教程
数学公式高效处理全流程:从截图识别到专业排版 每次在论文或笔记中插入复杂的数学公式时,你是否也经历过这样的痛苦?反复核对LaTeX代码中的每个括号,调整上下标位置,或是为了一个特殊符号翻遍文档。传统的手动输入方式…...
【24年最新算法】首发CPO-XGBoost回归+交叉验证 基于冠豪猪优化算法-XGBoost多变量回归预测
✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室👇 关注我领取海量matlab电子书和…...
