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

利用EMQX实现单片机和PyQt的数据MQTT互联

https://www.dong-blog.fun/post/2050

基于MQTT的设备监控与控制系统设计

引言

物联网(IoT)设备的远程监控与控制是现代智能系统的基础需求。本文将介绍一个基于MQTT协议的设备监控与控制系统,该系统由两部分组成:模拟单片机设备和PyQt客户端。我们将详细讨论系统的设计思路、代码实现以及实际应用场景。

系统架构

该系统基于发布-订阅模式,采用MQTT协议实现设备与客户端之间的双向通信。系统结构如下:

  1. 设备模拟器:模拟单片机设备,定期发送GPS位置数据,并接收控制命令
  2. PyQt客户端:显示设备GPS数据,并提供用户界面发送控制命令
  3. MQTT服务器:充当消息代理,负责转发消息

我在之前已经介绍了如何使用EMQT,这里不再重复,有关信息查看这里:

https://www.dong-blog.fun/post/1963

https://www.dong-blog.fun/post/2049

通信协议设计

系统使用两个主题进行通信:

  1. 设备数据主题(device/gps):设备向此主题发布GPS数据

    {"device_id": "device_001","timestamp": 1692345678,"latitude": 30.056789,"longitude": 120.123456
    }
    
  2. 控制指令主题(device/control):客户端向此主题发布控制命令

    • 按钮控制命令:
      {"command": "UP","timestamp": 1692345700
      }
      
    • 自定义文本命令:
      {"text": "自定义指令内容","timestamp": 1692345720
      }
      

通过区分commandtext键,系统能够清晰地区分不同类型的控制信号。

设备模拟器实现

设备模拟器(device_simulator.py)主要功能是:

  1. 模拟GPS数据采集并发布到MQTT服务器
  2. 接收并处理控制命令
import paho.mqtt.client as mqtt
import json
import time
import random# MQTT broker configuration
broker = "10.100.80.98"
port = 1883
topic = "device/gps"
control_topic = "device/control"# Create MQTT client with Version 2 API
client = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2)def on_connect(client, userdata, flags, rc, properties=None):print(f"Connected with result code {rc}")# Subscribe to control topicclient.subscribe(control_topic)print(f"已订阅控制主题: {control_topic}")def on_message(client, userdata, msg, properties=None):try:data = json.loads(msg.payload.decode())print(f"收到控制数据: {data}")# 处理不同类型的消息if "command" in data:command = data["command"]print(f"执行命令: {command}")# 这里可以添加对命令的具体响应逻辑if command == "UP":print("设备向上移动")elif command == "DOWN":print("设备向下移动")elif command == "LEFT":print("设备向左移动")elif command == "RIGHT":print("设备向右移动")elif command == "CONFIRM":print("设备确认操作")elif command == "CANCEL":print("设备取消操作")# 处理自定义文本消息elif "text" in data:text = data["text"]print(f"收到自定义文本: {text}")# 处理文本命令的逻辑print(f"设备执行文本命令: {text}")except Exception as e:print(f"处理消息时出错: {e}")# Set callback functions
client.on_connect = on_connect
client.on_message = on_message# Connect to broker
try:client.connect(broker, port, 60)# Start the network loopclient.loop_start()print(f"已连接到MQTT服务器: {broker}:{port}")
except Exception as e:print(f"连接MQTT服务器失败: {e}")exit(1)try:device_id = "device_001"print(f"设备 {device_id} 模拟器开始运行")print("按Ctrl+C停止程序")while True:# Generate random GPS coordinates around a specific location# Base coordinates: 30.0°N, 120.0°Elatitude = 30.0 + random.uniform(-0.1, 0.1)longitude = 120.0 + random.uniform(-0.1, 0.1)# Create message payloadmessage = {"device_id": device_id,"timestamp": int(time.time()),"latitude": round(latitude, 6),"longitude": round(longitude, 6)}# Publish messageclient.publish(topic, json.dumps(message))print(f"已发送GPS数据: 纬度={message['latitude']}, 经度={message['longitude']}")# Wait for 2 seconds before sending next messagetime.sleep(2)except KeyboardInterrupt:print("\n接收到停止信号,正在停止设备模拟器...")client.loop_stop()client.disconnect()print("设备模拟器已停止")
except Exception as e:print(f"运行时错误: {e}")client.loop_stop()client.disconnect() 

设备模拟器使用随机生成的GPS坐标数据,模拟设备移动的场景,同时能够对不同类型的命令做出响应。

日志信息:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

PyQt客户端实现

PyQt客户端(gps_monitor.py)提供了图形界面,主要功能包括:

  1. 显示设备GPS数据
  2. 提供方向控制按钮
  3. 支持自定义文本命令输入和发送

客户端的核心在于MQTT与PyQt的集成,我们使用信号-槽机制来解决多线程问题:

import sys
import json
import time
import paho.mqtt.client as mqtt
from PyQt5.QtWidgets import (QApplication, QMainWindow, QWidget, QVBoxLayout, QHBoxLayout, QPushButton, QTextEdit, QLabel)
from PyQt5.QtCore import Qt, QTimer, pyqtSignal, QObject# 创建一个MQTT信号处理类
class MQTTSignals(QObject):message_received = pyqtSignal(dict)class GPSMonitor(QMainWindow):def __init__(self):super().__init__()self.setWindowTitle("GPS Monitor and Controller")self.setGeometry(100, 100, 800, 600)# MQTT setupself.broker = "10.100.80.98"self.port = 1883self.gps_topic = "device/gps"self.control_topic = "device/control"# 创建信号对象self.mqtt_signals = MQTTSignals()self.mqtt_signals.message_received.connect(self.update_display)self.setup_mqtt()self.setup_ui()def setup_mqtt(self):# 使用MQTT V5客户端self.client = mqtt.Client(mqtt.CallbackAPIVersion.VERSION2)self.client.on_connect = self.on_connectself.client.on_message = self.on_messagetry:self.client.connect(self.broker, self.port, 60)self.client.loop_start()except Exception as e:print(f"MQTT连接错误: {e}")def on_connect(self, client, userdata, flags, rc, properties=None):print(f"Connected with result code {rc}")self.client.subscribe(self.gps_topic)def on_message(self, client, userdata, msg, properties=None):try:data = json.loads(msg.payload.decode())# 使用信号发送数据,不直接更新UIself.mqtt_signals.message_received.emit(data)except Exception as e:print(f"Error processing message: {e}")def setup_ui(self):# Main widget and layoutmain_widget = QWidget()self.setCentralWidget(main_widget)layout = QVBoxLayout(main_widget)# GPS display areaself.gps_display = QTextEdit()self.gps_display.setReadOnly(True)layout.addWidget(self.gps_display)# Control buttons layoutbutton_layout = QHBoxLayout()# Direction buttonsself.btn_up = QPushButton("上")self.btn_down = QPushButton("下")self.btn_left = QPushButton("左")self.btn_right = QPushButton("右")self.btn_confirm = QPushButton("确认")self.btn_cancel = QPushButton("取消")# Add buttons to layoutbutton_layout.addWidget(self.btn_up)button_layout.addWidget(self.btn_down)button_layout.addWidget(self.btn_left)button_layout.addWidget(self.btn_right)button_layout.addWidget(self.btn_confirm)button_layout.addWidget(self.btn_cancel)# Command inputself.command_input = QTextEdit()self.command_input.setMaximumHeight(100)layout.addWidget(QLabel("命令输入:"))layout.addWidget(self.command_input)# Send buttonself.btn_send = QPushButton("发送")layout.addWidget(self.btn_send)# Add button layout to main layoutlayout.addLayout(button_layout)# Connect button signalsself.btn_up.clicked.connect(lambda: self.send_command("UP"))self.btn_down.clicked.connect(lambda: self.send_command("DOWN"))self.btn_left.clicked.connect(lambda: self.send_command("LEFT"))self.btn_right.clicked.connect(lambda: self.send_command("RIGHT"))self.btn_confirm.clicked.connect(lambda: self.send_command("CONFIRM"))self.btn_cancel.clicked.connect(lambda: self.send_command("CANCEL"))self.btn_send.clicked.connect(self.send_custom_command)def update_display(self, data):display_text = f"时间戳: {data['timestamp']}\n"display_text += f"设备ID: {data['device_id']}\n"display_text += f"纬度: {data['latitude']}\n"display_text += f"经度: {data['longitude']}\n"display_text += "-" * 50 + "\n"current_text = self.gps_display.toPlainText()self.gps_display.setText(display_text + current_text)def send_command(self, command):message = {"command": command,"timestamp": int(time.time())}self.client.publish(self.control_topic, json.dumps(message))print(f"已发送命令: {command}")def send_custom_command(self):command = self.command_input.toPlainText().strip()if command:# 使用"text"作为键名而不是"command"message = {"text": command,"timestamp": int(time.time())}self.client.publish(self.control_topic, json.dumps(message))self.command_input.clear()print(f"已发送自定义文本: {command}")def closeEvent(self, event):"""窗口关闭时的处理"""self.client.loop_stop()self.client.disconnect()event.accept()if __name__ == "__main__":app = QApplication(sys.argv)window = GPSMonitor()window.show()sys.exit(app.exec_()) 

这种设计解决了MQTT回调线程与GUI线程的冲突问题,确保了应用程序的稳定性。

PyQt运行界面:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

线程安全设计

MQTT客户端的回调函数在非GUI线程中执行,而PyQt应用程序要求UI更新必须在主线程中进行。为了解决这个问题,我们采用了Qt的信号-槽机制:

  1. 创建一个MQTTSignals类,定义message_received信号
  2. 在MQTT回调函数中发射信号
  3. 将信号连接到GUI线程中的槽函数

这种方式确保了线程安全,避免了直接在回调函数中更新UI导致的崩溃问题。

系统扩展性

该系统具有良好的扩展性:

  1. 多设备支持:通过增加设备ID识别,可轻松扩展为多设备系统
  2. 协议扩展:可以增加新的消息类型和命令
  3. 功能增强:可以添加历史数据记录、轨迹显示、报警功能等

系统运行效果

系统运行后,设备模拟器会每2秒发送一次GPS数据,PyQt客户端会实时显示这些数据,并可通过按钮或自定义文本发送控制命令。设备模拟器收到命令后会打印相应的响应信息。

源码与使用方法

使用前需要安装必要的依赖:

pip install paho-mqtt PyQt5

要运行系统,请先启动设备模拟器,然后运行PyQt客户端:

python device_simulator.py
python gps_monitor.py

相关文章:

利用EMQX实现单片机和PyQt的数据MQTT互联

https://www.dong-blog.fun/post/2050 基于MQTT的设备监控与控制系统设计 引言 物联网(IoT)设备的远程监控与控制是现代智能系统的基础需求。本文将介绍一个基于MQTT协议的设备监控与控制系统,该系统由两部分组成:模拟单片机设备和PyQt客户端。我们将…...

C#/.NET/.NET Core技术前沿周刊 | 第 36 期(2025年4.21-4.27)

前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录、追踪C#/.NET/.NET Core领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿,助力技术成长与视野拓宽。 欢迎投稿、推荐…...

Context7 MCP:提供实时、版本特定的文档以解决AI幻觉问题

在实际开发中,使用AI辅助编码常常出现令人沮丧的问题:AI提供的API调用建议往往已经过时,或者根本不存在。 特别是当您使用最新版库时,这个问题尤为明显。 Upstash团队开发的Context7开源工具正是为解决这一痛点而生。 版本不匹配导致的API错误 现代开发库迭代速度快,常…...

电路研究9.3.2——合宙Air780EP中的AT开发指南:HTTP(S)-PDP的研究

按照推荐的GPRS模块的学习顺序,现在需要研究的是HTTP(S)了,所以我们就继续学习吧。 9.5.2 HTTP(S)应用指南 应用概述 4G 模块支持 HTTP 和 HTTPS 协议(这个确实也考虑过了,但是不知道合不合适呢,而且我们计划的通讯是只…...

K8S ConfigMap 快速开始

一、什么是 ConfigMap? ConfigMap 是 Kubernetes 中用于存储非敏感配置数据的 API 对象,支持以键值对(Key-Value)或文件的形式存储配置,允许将配置与镜像解耦,实现配置的集中管理和动态更新。 二、主要用…...

【星海出品】K8S调度器leader

发现K8S的技术资料越写越多,独立阐述一下K8S-Scheduler-leader 调度器通过Watch机制来发现集群中【新创建】且尚未被调度【unscheduled】到节点上的pod。 由于 Pod 中的容器和 Pod 本身可能有不同的要求,调度程序会过滤掉任何不满足 Pod 特定调度需求的…...

第十二届蓝桥杯 2021 C/C++组 空间

目录 题目: 题目描述: 题目链接: 思路: 思路详解: 代码: 代码详解: 题目: 题目描述: 题目链接: 空间 - 蓝桥云课 思路: 思路详解&#…...

通过深度学习推进增材制造:当前进展与未来挑战综述

通过深度学习推进增材制造:当前进展与未来挑战综述 ​原文信息​: 标题:Advancing Additive Manufacturing through Deep Learning: A Comprehensive Review of Current Progress and Future Challenges 作者:Amirul Islam Saimon, Emmanuel Yangue, Xiaowei Yue, Zhenyu (…...

深入蜂窝物联网 第三章 LTE-M(Cat-M1)详解:省电机制与移动特性

1. 前言与应用场景 在蜂窝物联网阵营中,LTE-M(Cat-M1) 兼具低功耗和中速率,且支持移动场景下的无缝切换,因而成为物流追踪、可穿戴设备、智能路灯、共享单车等场景的首选。 本章将系统剖析: 核心特性:PSM、eDRX 与移动性保障; 协议流程:简化的 RRC/NAS 步骤; 时序图…...

软件设计师速通其一:计算机内部数据表示

考试资料推荐 ,这也是大部分图片的出处。本文章主要将视频原本讲的不详细、不便于理解的东西摆开揉碎了给到读者。相信本文能帮您更好更快的学习知识。本文也是您考前快速复习的不二之选。本文会用星星来表示每个考点的重要性,其中一颗★表示课外拓展&am…...

Kubernetes》》k8s》》Taint 污点、Toleration容忍度

污点 》》 节点上 容忍度 》》 Pod上 在K8S中,如果Pod能容忍某个节点上的污点,那么Pod就可以调度到该节点。如果不能容忍,那就无法调度到该节点。 污点和容忍度的概念 》》污点等级——>node 》》容忍度 —>pod Equal——>一种是等…...

【爬虫】一文掌握 adb 的各种指令(adb备忘清单)

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 入门设备基础Logcat文件管理远程 Shell包安装Paths手机信息包信息设备相关命令权限Logs常见的 ADB 命令将文件推送到 Android 设备的下载文件夹列出所有已安装的包并获取完整路径从安卓设备中提取文件从主机安装 APK 到…...

1.7无穷级数

引言 无穷级数是考研数学一的核心内容,涵盖数项级数、幂级数、傅里叶级数等核心概念。本文系统梳理4大考点,结合公式速查与实战示例,助你高效突破级数难点! 考点一:数项级数敛散性判定 1️⃣ 正项级数 (1) 比较审敛…...

vitest | 测试框架vitest | 总结笔记

测试框架 vitest 介绍 网址:Vitest | Next Generation testing framework 特点:①支持vite的生态系统,②兼容jest语法 ③HMR测试(速度快) ④ ESM(js的原生支持) 安装 Vitest: npm …...

使用 ELK 实现全链路追踪:从零到一的实践指南

前言 在现代分布式系统中,随着服务数量的增加,系统的复杂性也呈指数级增长。为了快速定位问题、分析性能瓶颈,全链路追踪成为一项必不可少的能力。本文将详细介绍如何利用 ELK(Elasticsearch Logstash Kibana) 实现…...

AI智能体开发实战:从概念到落地的全流程解析

一、AI智能体:重新定义人机协作 什么是AI智能体? AI智能体是具备感知-思考-行动闭环能力的程序实体,能够通过传感器(如文本输入、图像识别)获取信息,基于大模型推理决策,并通过API、机器人等执…...

如何搭建spark yarn 模式的集群

搭建Spark on YARN集群的步骤 Spark on YARN模式允许Spark作业在Hadoop YARN资源管理器上运行,这样可以更好地与Hadoop生态系统集成并共享集群资源。以下是搭建Spark YARN集群的详细步骤: 前提条件 已安装并配置好Hadoop集群(包括HDFS和YAR…...

DDoS 攻击如何防护?2025最新防御方案与实战指南

一、DDoS 攻击的致命威胁:你的业务离瘫痪有多近? 1. 2024 年 DDoS 攻击现状 攻击规模:全球日均攻击峰值突破7.2Tbps,混合型攻击占比超 65%(来源:Cloudflare)行业重灾区: 行业攻击占…...

3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目

安装 pnpm install icraft/player-react --saveimport { ICraftPlayer } from "icraft/player-react";export default function MyScene() {return <ICraftPlayer srcyour-scene.iplayer />; }icraft/player-react 为开发者提供了一站式的3D数字孪生可视化解决…...

esm使用-包括esmfold和embedding

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言零、安装一、esmfold的使用二、esm2的embedding1.模型加载与准备2.读入数据3.提取残基级表示4.生成序列级表示(均值池化)5.可视化自注意力接触图6.潜在问题与改进建议7.小结总结前言 主要参…...

【Nginx】 使用least_conn负载均衡算法是否能将客户端的长连接分散到不同的服务器上demo

为了验证Nginx在关闭HTTP Keepalive的情况下&#xff0c;使用least_conn负载均衡算法是否能将客户端的长连接分散到不同的服务器上&#xff0c;我们可以搭建一个简单的环境。这个环境包括&#xff1a; 一个Nginx服务器作为负载均衡器。两个后端服务器&#xff08;可以使用简单…...

TMI投稿指南(三):共同作者

IEEE 作者编辑风格手册 --- IEEE Editorial Style Manual for Authors 投稿之后检查路径&#xff1a; IEEE 作者门户&#xff1a;登录 --- IEEE Author Gateway: Login 共同第一作者&#xff1a;在许多领域&#xff0c;被视为成为第一作者是件好事。但只有一个人可以是第一作…...

Java多线程入门案例详解:继承Thread类实现线程

本文通过一个简单案例&#xff0c;讲解如何通过继承 Thread 类来实现多线程程序&#xff0c;并详细分析了代码结构与运行机制。 一、前言 在 Java 中&#xff0c;实现多线程主要有两种方式&#xff1a; 继承 Thread 类 实现 Runnable 接口 本文以继承 Thread 类为例&#x…...

Transformer Prefill阶段并行计算:本质、流程与思考

Transformer Prefill阶段并行计算&#xff1a;本质、流程与思考 “为什么Transformer在Prefill阶段可以并行&#xff1f;并行到什么程度&#xff1f;哪里还需要同步&#xff1f;今天讲清楚&#xff01;” 引子 在大语言模型&#xff08;LLMs&#xff09;爆发的时代&#xff0c…...

KUKA机器人自动备份设置

在机器人的使用过程中&#xff0c;对机器人做备份不仅能方便查看机器人的项目配置与程序&#xff0c;还能防止机器人项目和程序丢失时进行及时的还原&#xff0c;因此对机器人做备份是很有必要的。 对于KUKA机器人来说&#xff0c;做备份可以通过U盘来操作。也可以在示教器上设…...

Lua 第13部分 位和字节

13.1 位运算 Lua 语言从 5.3 版本开始提供了针对数值类型的一组标准位运算符。与算术运算符不同的是&#xff0c;位运算符只能用于整型数。位运算符包括 &#xff06;&#xff08; 按位与&#xff09;、&#xff5c;&#xff08;按位或&#xff09;、&#xff5e;&#xff08;按…...

下载同时返回其他参数

一般情况下下载的接口是没有返回值的&#xff0c;直接返回一个文件 浏览器直接触发文件下载 但是有一些奇葩需求&#xff0c;除了文件外还需要一些其他字段返回。这个时候就只能把文件转成字符串返回&#xff0c;然后再由前端做下载或者展示 后台获取字符 byte[] byte[] bo…...

240428 leetcode exercises

240428 leetcode exercises jarringslee 文章目录 240428 leetcode exercises[25. K 个一组翻转链表 ](https://leetcode.cn/problems/reverse-nodes-in-k-group/solutions/3663828/xian-fan-zhuan-lian-biao-zai-kyi-ge-zu-f-lgaj/)&#x1f501; 探宗求源 其义自见 [75. 颜色…...

SQLMesh 审计与测试:确保数据质量的利器

在数据科学项目中&#xff0c;确保数据质量和准确性至关重要。SQLMesh 提供了审计和测试两种工具来验证数据。本文将介绍 SQLMesh 的审计功能&#xff0c;并与测试进行对比&#xff0c;帮助您更好地理解如何在项目中使用这些工具。 SQLMesh 审计 SQLMesh 的审计功能可以帮助您…...

SQL Server 存储过程开发规范

SQL Server 存储过程开发规范&#xff08;高级版&#xff09; 1. 总则 1.1 目标 本规范旨在&#xff1a; 提高存储过程的事务一致性、异常可追踪性、错误透明度。 统一日志记录、错误码管理、链路追踪&#xff08;Trace ID&#xff09;。 支持复杂事务场景&#xff08;嵌套…...

图像处理篇---信号与系统的应用

文章目录 前言一、信号表示层面图像作为二维信号二、系统特性分析线性移变系统建模采样系统理论应用时域采样定理在帧率选择中的应用三、变换域处理多维傅里叶分析小波变换与多分辨率分析四、系统响应特性人类视觉系统(HVS)建模摄像机系统响应五、编码系统中的信号处理预测编…...

什么是 Web 标准?为什么它们对 SEO 和开发很重要?

网页标准为何重要&#xff1f;谷歌解析SEO优势 在当今数字营销领域&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;是网站提升可见性和吸引自然流量的关键策略。然而&#xff0c;许多网站管理员和营销人员可能忽略了一个重要的SEO因素——网页标准。谷歌的SEO专家深入解…...

Python 正则表达式 re 包

一、常见正则表达式符号 符号含义示例.匹配任意单个字符&#xff08;除了换行&#xff09;r"a.c" 可匹配 "abc"、"a1c" 等\d匹配任何数字&#xff08;0-9&#xff09;r"\d" 匹配 "123"、"56"\w匹配字母、数字或下…...

leetcode0230. 二叉搜索树中第 K 小的元素-medium

1 题目&#xff1a;二叉搜索树中第 K 小的元素 官方标定难度&#xff1a;中 给定一个二叉搜索树的根节点 root &#xff0c;和一个整数 k &#xff0c;请你设计一个算法查找其中第 k 小的元素&#xff08;从 1 开始计数&#xff09;。 示例 1&#xff1a; 输入&#xff1a;r…...

Linux环境变量配置与std访问环境变量

文章目录 前言1. 用户环境变量快速配置1.2 **以上语句的具体解释&#xff1a;**1.3 $PATHNAME实现增量式添加 2.系统级永久配置与避坑指南2.1 特殊字符处理2.2 动态PATH管理2.3 敏感信息保护2.4 环境调试命令 3. cstd中访问环境变量 前言 首先介绍一下Linux下各目录操作符的含…...

【go】go语言slice/map的产生背景,及原理理解

介绍一下Slice 先讲一下slice的产生背景&#xff0c;首先&#xff0c;go本身是有数组的&#xff0c;但是不会自动扩容&#xff0c;然而实际工作中会有很多场景是要求能自动扩容的&#xff0c;比如说你接用户的数据&#xff0c;你肯定要设置一个可以自动扩容的数组来接&#xff…...

机器学习day3 - KNN的api调用

使用KNN算法判断是否为传入的图片是否为苹果 """ 使用KNN算法判断是否为传入的图片是否为苹果 """ # 导入需要的库 from sklearn.model_selection import train_test_split # 导入数据集划分函数 from sklearn.preprocessing import StandardS…...

Qt内置图标速查表

文章目录 1、说明&#x1f33e;2、实现效果&#x1f331;Qt6.7以下版本Qt6.7以上版本 3、主要代码&#x1f333; 更多精彩内容&#x1f449;个人内容分类汇总 &#x1f448; 1、说明&#x1f33e; 在我们使用Qt开发程序时&#xff0c;需要美化界面总会想到贴图&#xff0c;显示…...

Python(14)推导式

在 Python 编程中&#xff0c;推导式是一种强大而简洁的语法结构&#xff0c;它能让开发者以简洁的方式从一个数据序列创建另一个新的数据序列。无论是处理列表、字典、集合还是元组&#xff0c;推导式都能大显身手。这篇博客将结合菜鸟教程中的内容&#xff0c;通过丰富的代码…...

React速通笔记

相关视频&#xff1a; 黑马程序员前端React18入门到实战视频教程&#xff0c;从reacthooks核心基础到企业级项目开发实战&#xff08;B站评论、极客园项目等&#xff09;及大厂面试全通关_哔哩哔哩_bilibili 一、React介绍 React由Meta公司开发&#xff0c;是一个用于 构建W…...

深入蜂窝物联网:第二章 深度解读 NB-IoT:协议栈、部署与典型应用

1. NB-IoT 简介与应用场景 NB-IoT(Narrowband-IoT,窄带物联网)是3GPP在LTE演进基础上,为海量低速率IoT设备设计的无线接入技术。它仅占用 200 kHz 或 180 kHz(Guard-band)带宽,通过扩频和重复发射,提高了深度覆盖能力。 典型应用 远程抄表:电表、水表、气表等周期性少…...

处理对象集合,输出Map<String, Map<String, List<MyObject>>>格式数据,无序组合键处理方法

需求&#xff1a;对象有字段A&#xff0c;B&#xff0c;C&#xff0c;需要判断对象之间AB两个字段相同的对象 如&#xff1a; 对象1&#xff0c;Aaaa,Bbbb 对象2&#xff0c;Aaaa,Bbbb 对象3&#xff0c;Abbb,Baaa 对象4&#xff0c;Abbb,Baaa…...

基于SpringBoot的食物营养分析与推荐网站系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

人智交互中的AI世代

人智交互中的AI世代 一、研究背景与意义 1.1 技术演进背景 人工智能技术自1956年达特茅斯会议提出概念以来&#xff0c;经历了多次技术迭代与产业周期。2020年后&#xff0c;以大语言模型&#xff08;LLMs&#xff09;和生成式AI&#xff08;AIGC&#xff09;为代表的突破性进…...

从Flask到智能体:装饰器模式在AI系统中的架构迁移实践

引言&#xff1a;框架设计中的模式复用 在人工智能系统开发领域&#xff0c;大型语言模型驱动的智能体&#xff08;LLM Agent&#xff09;正面临日益复杂的架构挑战。有趣的是&#xff0c;Web开发框架Flask的装饰器模式为此类系统的构建提供了极具启发性的解决方案。本文将深入…...

Docker的常用命令

docker的常用命令 今天来介绍docker的常用命令&#xff0c;非常的详细&#xff0c;请大家看起来&#xff01; 获取镜像 如果只指定了镜像的名称&#xff0c;则默认会获取latest标签标记的镜像 命令格式&#xff1a;dokcer pull [Docker Registry地址]仓库名[:标签名] 获取c…...

在matlab中使用UAV123官方toolkits测试自己的数据集

一、前言 最近需要将自己的跟踪代码在自己拍摄的数据集上进行测试&#xff0c;这里我选择使用 UAV123 官方 toolkits 进行配置。首先需要搞清楚这部分代码是如何运行的&#xff0c;精度图和成功率图是如何绘制出来的&#xff0c;然后再将自己的数据集加进去进行测试。 二、UA…...

《淘宝 API 数据湖构建:实时商品详情入湖 + Apache Kafka 流式处理指南》

随着电商行业的蓬勃发展&#xff0c;淘宝作为头部电商平台&#xff0c;积累了海量的商品数据。构建淘宝 API 数据湖&#xff0c;将实时商品详情数据纳入其中&#xff0c;并借助 Apache Kafka 进行流式处理&#xff0c;能够为企业提供强大的数据支撑&#xff0c;助力精准营销、市…...

HTML5 WebSocket:实现高效实时通讯

一、引言 在当今的 Web 开发领域,实时通讯功能变得越来越重要。例如在线聊天、实时数据更新等场景都需要客户端与服务器之间能够进行高效的双向数据传输。HTML5 引入的 WebSocket 协议为我们提供了一种强大的解决方案,它在单个 TCP 连接上实现了全双工通讯,极大地改善了传统…...

数字人Live_Talking的搭建和使用

Live_Talking是一个实时交互流式数字人&#xff0c;可以实现音视频同步对话。今天咱们来试着部署一下项目。 先来看下本地环境 系统&#xff1a;Ubuntu 22.04 显卡&#xff1a;rtx 3060 cuda: Cuda 12.1 git上推荐cuda11.3&#xff0c;但是我用cuda12.2也搭建成功了。 1、…...