当前位置: 首页 > article >正文

常见的函数使用(一)

contains()介绍contains()是 Qt 中多个核心容器类如QJsonObject、QMap、QString、QByteArray等提供的成员函数核心作用是检查当前容器中是否包含指定的 “目标元素”返回值是布尔类型true 表示包含false 表示不包含读取QJsonObject不存在的键、查找QString不存在的子串等换言之可以用来做查找功能比如if(reacthtext.isEmpty()||Item.content.contains(reacthtext,Qt::CaseInsensitive))判断搜索的文本有没有符合的检查JSON对象中是否包含指定的键keyif(!obj.contains(score))检查字节数组中是否包含指定的字节 / 字节串常用于二进制数据校验bool isPngimgData.contains(\x89PNG);QVariant介绍 万能容器它能存储几乎所有 Qt 内置类型如int、QString、QByteArray、QImage和开发者自定义的类对象并且能在需要时安全地还原为原始类型基础操作存储打包→ 查看类型 → 读取拆包直接打包QVariantvar3(QByteArray(binary data));// 存储 QByteArray使用通用方式 使用fromValueQVariant var4QVariant::fromValue(imageData);// 存储 QByteArray读取拆包//valueT()QByteArray bytesvar4.valueQByteArray();结合Qt::UserRole来讲QVariantQVariant varImgQVariant::fromValue(imageData);listItem-setData(varImg,Qt::UserRole);//Qt::UserRole用户自定义类型//读取 QByteArrayUserRole 分区QVariant readVarImgreadItem-data(Qt::UserRole);// 取万能容器QByteArray readImgreadVarImg.valueQByteArray();// 拆包还原//同时也能合并起来QByteArray readImgeadItem-data(Qt::UserRole).valueQByteArray()Qt::UserRole是 “起始值”不是唯一值Qt::UserRole 256是自定义分区的第一个位置如果需要存多个自定义数据用Qt::UserRole 1、Qt::UserRole 2...区分比如一个存图片一个存自定义类不管你存的是QByteArray、ClipboardItem还是int都必须先打包成QVariantfromValue()才能存入UserRole分区QMimeData介绍跨控件 / 跨应用传递数据时会面临两个核心问题数据类型多样文本、图片、文件、自定义数据需要统一的容器封装接收方无法识别数据格式容易解析出错多类型数据共存示例QMimeData*mimeDatanewQMimeData();mimeData-setText(Qt 剪贴板测试文本);mimeData-setHtml(h1Qt 剪贴板测试/h1);QImageimage(test.png);QByteArray imgData;QBufferbuffer(imgData);buffer.open(QIODevice::WriteOnly);image.save(buffer,PNG);mimeData-setData(image/png,imgData);clipboard-setMimeData(mimeData);// 存入剪贴板Qt 自动管理内存//从剪切板读取数据constQMimeData*clipMimeclipboard-mimeData();if(clipMime){// 校验并读取纯文本if(clipMime-hasText()){qDebug()剪贴板文本clipMime-text();}// 校验并读取自定义 MIME 类型的图片if(clipMime-hasFormat(image/png)){QByteArray readImgclipMime-data(image/png);QImage readImage;readImage.loadFromData(readImg);qDebug()图片尺寸readImage.size();}}也能识别自定义类型使用的是hasFormat()// 自定义 MIME 类型application/myapp-clipboardmimeData-setData(application/myapp-clipboard,QVariant::fromValue(item).toByteArray());// 解析自定义 MIME 类型数据constQMimeData*readMime...;if(readMime-hasFormat(application/myapp-clipboard)){QByteArray datareadMime-data(application/myapp-clipboard);QVariant varQVariant::fromByteArray(data);ClipboardItem readItemvar.valueClipboardItem();mimeData的setdata和listItem的setdata名字重名但其实本质不一样比如参入的参数的顺序就能看出来当然高版本的也可能进行了参数的修改这个主要还是得看帮助文档里边写的参数的位置QJsonObject 介绍专门用于处理JSON对象 的核心类与 Qt 其他JSON类QJsonValue、QJsonArray、QJsonDocument配合完成完整的JSON序列化对象→字符串和反序列化字符串→对象键是QString类型值是QJsonValue类型可封装字符串、数字、布尔、数组、嵌套对象等值可以是QJsonArrayJSON数组或另一个QJsonObject嵌套JSON对象#includeQCoreApplication#includeQJsonObject#includeQJsonDocument#includeQDebugintmain(intargc,char*argv[]){QCoreApplicationa(argc,argv);// 步骤1创建 QJsonObject 并添加键值对 QJsonObject userObj;// 方式1insert() 插入键值对支持所有 JSON 基础类型userObj.insert(name,张三);// 字符串值userObj.insert(age,25);// 整数值userObj.insert(isStudent,false);// 布尔值userObj.insert(score,98.5);// 浮点值userObj.insert(hobby,QJsonValue(编程));// 显式封装为 QJsonValue// 方式2[] 运算符直接赋值更简洁userObj[address]北京市;// 嵌套对象值是另一个 QJsonObjectQJsonObject contactObj;contactObj[phone]13800138000;//这里就能自定义json化对象写一个json函数,定义一个QJsonObject 对象然后将传入的参数复制给该对象之后返回该对象即可contactObj[email]zhangsanexample.com;userObj[contact]contactObj;// 嵌套到主对象// 嵌套数组值是 QJsonArrayQJsonArray tagsArray;tagsArray.append(Qt);tagsArray.append(JSON);tagsArray.append(C);userObj[tags]tagsArray;// 步骤2读取 QJsonObject 中的值 // 核心先检查键是否存在contains()再读取避免读取不存在的键if(userObj.contains(name)){QString nameuserObj[name].toString();// 转换为字符串qDebug()姓名name;// 输出张三}if(userObj.contains(age)){intageuserObj.value(age).toInt();// value() 等价于 []qDebug()年龄age;// 输出25}// 读取嵌套对象if(userObj.contains(contact)){QJsonObject contactuserObj[contact].toObject();QString phonecontact[phone].toString();qDebug()电话phone;// 输出13800138000}// 读取嵌套数组if(userObj.contains(tags)){QJsonArray tagsuserObj[tags].toArray();for(inti0;itags.size();i){qDebug()标签itags[i].toString();}}// 步骤3修改/删除键值对 userObj[age]26;// 修改已有键的值userObj.remove(hobby);// 删除指定键qDebug()删除 hobby 后是否存在userObj.contains(hobby);// false// 步骤4序列化QJsonObject → JSON 字符串 QJsonDocumentdoc(userObj);// 格式化输出Indented易读Compact紧凑无空格适合传输QString jsonStrdoc.toJson(QJsonDocument::Indented);qDebug()JSON 字符串\njsonStr;// 步骤5反序列化JSON 字符串 → QJsonObject QByteArray jsonBytesjsonStr.toUtf8();QJsonDocument doc2QJsonDocument::fromJson(jsonBytes);if(doc2.isObject()){// 先判断是否为 JSON 对象而非数组QJsonObject obj2doc2.object();qDebug()反序列化后的年龄obj2[age].toInt();// 输出26}returna.exec();}

相关文章:

常见的函数使用(一)

contains()介绍 contains() 是 Qt 中多个核心容器类(如 QJsonObject、QMap、QString、QByteArray 等)提供的成员函数,核心作用是:检查当前容器中是否包含指定的 “目标元素”,返回值是布尔类型(true 表示包…...

ChatGPT API购买与集成实战:从注册到生产环境部署全指南

ChatGPT API购买与集成实战:从注册到生产环境部署全指南 作为一名开发者,当你想把ChatGPT的强大能力集成到自己的应用里时,第一步往往就卡在了“怎么买”和“怎么用”上。网上的信息零散,官方文档虽然详尽但不够“接地气”&#…...

Phi-3-mini-4k-instruct与Typora集成:智能文档编写

Phi-3-mini-4k-instruct与Typora集成:智能文档编写 作为一名长期与技术文档打交道的开发者,我一直在寻找能够提升写作效率的工具组合。最近尝试将Phi-3-mini-4k-instruct与Typora结合使用,发现这个组合确实能带来意想不到的智能文档编写体验…...

百考通AI:数据分析智能生成,让数据决策更高效精准

在数字化时代,数据分析已成为学术研究、商业决策与项目推进的核心能力,但复杂的分析逻辑、繁琐的报告撰写常常让非专业人士望而却步。百考通AI(https://www.baikaotongai.com)凭借专业化的数据分析功能,为广大学子、职…...

百考通AI:实践报告智能生成,让实习总结更高效专业

每一段实习实践的收尾,都绕不开一份详实规范的实践报告。从梳理实习经历到提炼成长收获,从搭建报告框架到打磨文字表达,繁琐的撰写流程常常让学子们倍感疲惫。百考通AI(https://www.baikaotongai.com)凭借智能化的实践…...

Asian Beauty Z-Image Turbo镜像免配置:自动检测CUDA版本并匹配最优BF16策略

Asian Beauty Z-Image Turbo镜像免配置:自动检测CUDA版本并匹配最优BF16策略 东方美学图像生成从未如此简单 - 无需复杂配置,自动适配你的硬件环境 1. 项目简介:专为东方美学打造的智能图像生成工具 Asian Beauty Z-Image Turbo是一款基于先…...

百考通AI:任务书智能生成,让学术研究起步更清晰规范

在学术研究与项目开展的初期,一份逻辑严谨、要求明确的任务书是指引方向的核心纲领,却也让无数研究者倍感困扰:从梳理研究内容到明确技术目标,从规范格式到细化要求,繁琐的撰写流程常常耗费大量时间与精力。百考通AI&a…...

百考通AI:答辩PPT智能生成,让毕业答辩更从容

毕业答辩是学术生涯的关键一战,一份逻辑清晰、专业美观的PPT是顺利通关的核心保障,却也让无数毕业生熬夜奋战:从提炼研究核心到规划答辩流程,从设计页面排版到打磨讲稿,繁琐的准备工作常常让人焦头烂额。百考通AI&…...

春联生成模型-中文-base多场景落地:博物馆数字展厅AI互动春联生成终端

春联生成模型-中文-base多场景落地:博物馆数字展厅AI互动春联生成终端 春节,是中国人最重视的传统节日,而春联则是这个节日里不可或缺的文化符号。过去,写春联需要笔墨纸砚,考验的是书法功底和文学素养。如今&#xf…...

惩罚回归选型指南:什么时候该用岭回归、Lasso还是弹性网络?

惩罚回归选型实战:从原理到R语言实现的三维决策框架 当你的数据集里塞满了数十个甚至上百个预测变量时,传统线性回归就像个过度热情的新手——它会给每个变量都分配一个系数,哪怕某些变量只是数据噪声的伪装者。我曾在一个客户流失预测项目中…...

Transformer训练中的交叉熵损失:为什么它适合文本生成任务?

Transformer训练中的交叉熵损失:为什么它适合文本生成任务? 在自然语言处理领域,Transformer架构已经成为文本生成任务的事实标准。从机器翻译到对话系统,从文本摘要到代码生成,这种基于自注意力机制的模型展现出了惊人…...

HarmonyOS开发实战:页面与自定义组件生命周期的那些坑,你踩过几个?

HarmonyOS开发实战:页面与自定义组件生命周期的那些坑,你踩过几个? 在HarmonyOS应用开发中,生命周期管理是构建稳定、高效应用的核心技能。许多开发者虽然熟悉基础的生命周期回调,但在实际项目中仍会遇到各种意料之外的…...

一站式解决Visual C++运行库问题:从诊断到修复的完整指南

一站式解决Visual C运行库问题:从诊断到修复的完整指南 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 在Windows应用运行环境中,Visual …...

Unity游戏安全实战:如何用Zygisk-IL2CppDumper动态分析你的游戏代码(附防御方案)

Unity游戏安全实战:动态分析与防御的艺术 在移动游戏开发领域,安全防护与破解攻防始终是一场没有硝烟的战争。作为Unity开发者,我们既需要了解前沿的逆向分析技术来评估自身产品的安全强度,又需要掌握有效的防御手段来保护来之不易…...

Qwen3-14b_int4_awq效果实测:中文事实性核查、数学推理、逻辑链完整性分析

Qwen3-14b_int4_awq效果实测:中文事实性核查、数学推理、逻辑链完整性分析 1. 模型简介与部署验证 Qwen3-14b_int4_awq是基于Qwen3-14b模型的int4量化版本,采用AngelSlim技术进行压缩优化,专门用于高效文本生成任务。这个量化版本在保持较高…...

ofa_image-caption_coco_distilled_en参数详解:MODEL_LOCAL_DIR配置要点与常见加载失败解析

ofa_image-caption_coco_distilled_en参数详解:MODEL_LOCAL_DIR配置要点与常见加载失败解析 提示:本文基于 iic/ofa_image-caption_coco_distilled_en 镜像环境编写,实际操作前请确保已正确部署该镜像 1. 项目与模型简介 OFA图像英文描述系统…...

Phi-3-vision-128k-instruct效果展示:教辅材料图像识别与知识点自动标注

Phi-3-vision-128k-instruct效果展示:教辅材料图像识别与知识点自动标注 1. 模型能力概览 Phi-3-Vision-128K-Instruct 是一款轻量级的多模态模型,专注于高质量的文本和视觉数据处理。作为Phi-3模型家族的一员,它支持长达128K的上下文长度&…...

Phi-3-vision-128k-instruct惊艳效果:视频关键帧图文理解(单帧+时序推理)

Phi-3-vision-128k-instruct惊艳效果:视频关键帧图文理解(单帧时序推理) 1. 模型简介与核心能力 Phi-3-Vision-128K-Instruct是当前最先进的轻量级开放多模态模型,专注于高质量的文本和视觉数据推理。作为Phi-3模型家族成员&…...

元学习新视角:为什么MAML比传统预训练更适合你的NLP小样本任务?

元学习实战:为什么MAML在NLP小样本任务中比传统预训练更高效? 当你在处理一个只有几十条标注样本的泰语命名实体识别任务时,传统预训练模型的表现往往令人沮丧。去年我们团队遇到这个困境时,尝试了各种BERT变体的微调方法&#xf…...

Rancher UI突然挂掉?手把手教你排查K8s集群443端口冲突问题

Rancher UI突发故障?深度解析K8s集群443端口冲突排查全流程 凌晨三点,当告警短信惊醒睡梦中的你,发现Rancher管理界面突然无法访问,整个Kubernetes集群陷入瘫痪——这种场景对任何DevOps工程师来说都如同噩梦。本文将带你亲历一次…...

YOLOv12新手实战:快速上手YOLOv12n模型,体验高效目标检测

YOLOv12新手实战:快速上手YOLOv12n模型,体验高效目标检测 如果你对计算机视觉感兴趣,一定听说过YOLO这个名字。从YOLOv1到现在的YOLOv12,这个系列一直在刷新目标检测的速度和精度记录。但每次新版本出来,你是不是都有…...

RetinaFace实战教程:批量处理文件夹内所有jpg/png图片并分类保存结果

RetinaFace实战教程:批量处理文件夹内所有jpg/png图片并分类保存结果 1. 快速了解RetinaFace人脸检测 RetinaFace是一个强大的人脸检测模型,不仅能准确找到图片中的人脸位置,还能标出人脸的五个关键点:左右眼睛、鼻尖和两个嘴角…...

Phi-3-vision-128k-instruct效果实测:128K长上下文下的跨图逻辑推理能力

Phi-3-vision-128k-instruct效果实测:128K长上下文下的跨图逻辑推理能力 1. 模型概述 Phi-3-Vision-128K-Instruct是当前最先进的轻量级开放多模态模型,属于Phi-3模型家族的最新成员。这个模型最引人注目的特点是支持128K的超长上下文窗口,…...

FastAPI新手必看:如何用Jinja2动态加载HTML网站(附完整代码)

FastAPI与Jinja2实战:从零构建动态Web应用的完整指南 引言 在当今快速发展的Web开发领域,后端框架与前端模板的完美结合是构建高效动态网站的关键。FastAPI作为Python生态中崛起的新星,以其卓越的性能和简洁的API设计赢得了开发者的青睐。而J…...

万物识别镜像实战分享:智能相册自动分类应用

万物识别镜像实战分享:智能相册自动分类应用 1. 引言 1.1 从照片管理的烦恼说起 你有没有过这样的经历?手机相册里存了几千张照片,想找一张去年夏天在海边拍的照片,却要花上十几分钟甚至更久,在一堆杂乱无章的图片里…...

m4s媒体格式转换技术指南:从问题解析到跨平台实现

m4s媒体格式转换技术指南:从问题解析到跨平台实现 【免费下载链接】m4s-converter 将bilibili缓存的m4s转成mp4(读PC端缓存目录) 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 问题定位:m4s格式的技术瓶颈与解决方案 B站缓存文件…...

老设备新玩法:用OCP万兆网卡给MicroServer Gen8续命(含ESXI6.7配置全流程)

老设备新玩法:用OCP万兆网卡给MicroServer Gen8续命(含ESXI6.7配置全流程) 在硬件迭代飞快的今天,许多老设备依然具备强大的潜力等待挖掘。MicroServer Gen8作为一款经典的入门级服务器,凭借其稳定的性能和灵活的扩展性…...

统信UOS 20虚拟机安装全流程:从镜像下载到系统配置(附性能优化建议)

统信UOS 20虚拟机高效部署指南:从零配置到性能调优实战 在国产操作系统生态快速发展的今天,统信UOS作为国内领先的Linux发行版,正受到越来越多开发者和技术爱好者的关注。特别是在虚拟化环境中部署UOS 20,既能满足日常开发测试需求…...

Matlab神经网络训练避坑指南:trainingOptions()参数设置全解析(附常用配置模板)

Matlab神经网络训练避坑指南:trainingOptions()参数设置全解析 刚接触Matlab神经网络训练时,最令人头疼的莫过于trainingOptions()里那一长串参数。每次看到控制台里跳动的训练进度条,心里总在打鼓:这个学习率设得对不对&#xff…...

MCP vs Function Call:从原理到选型,开发者该如何选择?

MCP与Function Call深度对比:技术选型与架构设计实战指南 1. 技术范式之争的本质 在AI驱动的现代应用开发中,工具调用方式的选择直接影响系统的智能水平和扩展能力。MCP(Model Context Protocol)与Function Call代表着两种截然不同…...