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

从零到一:用Air724UG 4G模块和Python,手把手教你搭建一个物联网数据上报系统(含完整代码)

从零构建物联网数据上报系统Air724UG与Python实战指南在万物互联的时代物联网技术正悄然改变着我们的生活和工作方式。想象一下您只需轻点手机就能实时查看千里之外温湿度数据或是远程监控设备运行状态提前预警潜在故障。这种看似科幻的场景如今借助4G模块和简单编程就能实现。本文将带您从零开始使用Air724UG 4G模块和Python语言构建一套完整的物联网数据上报系统。这个项目特别适合那些已经掌握基础编程知识但渴望将零散技能整合为实际应用的开发者。不同于单纯的理论讲解我们将聚焦于端到端的实现过程——从硬件连接到云端展示每个环节都配有可落地的代码和配置说明。无论您是希望快速验证创意的极客还是需要实际部署监测系统的工程师都能从中获得实用价值。1. 硬件准备与环境搭建1.1 所需材料清单构建这套系统需要以下硬件组件Air724UG 4G模块支持LTE Cat1具备TCP/IP协议栈STM32/51单片机开发板作为数据采集终端SIM卡支持移动/联通/电信的物联网卡或普通流量卡温湿度传感器如DHT11或更精确的SHT30USB转TTL模块用于调试4G模块杜邦线若干用于各组件间连接提示购买Air724UG时注意选择带有IPEX天线接口的版本确保信号稳定性1.2 硬件连接示意图将各组件按以下方式连接[单片机] --(UART)-- [Air724UG] |--(I2C/GPIO)-- [温湿度传感器]具体接线参考下表组件接口连接目标引脚说明单片机TXAir724UG RX数据发送端单片机RXAir724UG TX数据接收端单片机GNDAir724UG GND共地连接单片机3.3VAir724UG VCC电源输入单片机SCL传感器SCLI2C时钟线单片机SDA传感器SDAI2C数据线1.3 开发环境配置在开始编程前需要准备好以下软件环境Python 3.8用于服务器端开发# 检查Python版本 python --versionPyCharm/VSCode推荐使用的IDEKeil MDK/STM32CubeIDE单片机开发环境串口调试工具如SecureCRT或Putty安装必要的Python库pip install pyserial flask sqlalchemy2. 4G模块配置与网络连接2.1 Air724UG基础AT指令测试通过USB转TTL模块连接电脑和Air724UG使用串口工具发送以下指令测试模块状态AT ATCPIN? # 查询SIM卡状态 ATCSQ # 检查信号强度 ATCOPS? # 查询当前运营商正常响应应类似AT OK CPIN: READY CSQ: 24,0 COPS: 0,0,CHINA MOBILE2.2 配置TCP/IP参数建立网络连接需要配置APN接入点名称不同运营商APN不同运营商APN设置指令中国移动ATCGDCONT1,IP,CMNET中国联通ATCGDCONT1,IP,UNINET中国电信ATCGDCONT1,IP,CTNET激活网络连接ATCGATT1 # 附着网络 ATNETOPEN # 打开网络 ATIPSTATUS # 查看网络状态2.3 建立TCP连接假设服务器IP为192.168.1.100端口为8080ATCIPOPEN0,TCP,192.168.1.100,8080 ATCIPSEND0,15 # 准备发送15字节数据 Hello,Server! # 输入要发送的数据成功连接后模块会返回CIPOPEN:0,0 CIPSEND:0,15,153. Python服务器开发3.1 TCP服务器实现创建一个简单的TCP服务器接收4G模块数据import socket def start_tcp_server(host0.0.0.0, port8080): with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s: s.bind((host, port)) s.listen() print(fServer listening on {host}:{port}) while True: conn, addr s.accept() with conn: print(fConnected by {addr}) while True: data conn.recv(1024) if not data: break print(fReceived: {data.decode()}) # 简单响应 conn.sendall(bACK: data) if __name__ __main__: start_tcp_server()3.2 数据解析与存储定义数据格式并存储到SQLite数据库from sqlalchemy import create_engine, Column, Integer, Float, DateTime from sqlalchemy.ext.declarative import declarative_base from sqlalchemy.orm import sessionmaker from datetime import datetime Base declarative_base() class SensorData(Base): __tablename__ sensor_data id Column(Integer, primary_keyTrue) temperature Column(Float) humidity Column(Float) timestamp Column(DateTime, defaultdatetime.now) engine create_engine(sqlite:///iot_data.db) Base.metadata.create_all(engine) Session sessionmaker(bindengine) def parse_and_store(raw_data): try: # 示例数据格式: T25.6H50.2 temp float(raw_data.split(T)[1].split(H)[0]) humi float(raw_data.split(H)[1]) session Session() new_data SensorData(temperaturetemp, humidityhumi) session.add(new_data) session.commit() return True except Exception as e: print(fError parsing data: {e}) return False3.3 Web数据展示界面使用Flask创建简单的数据可视化页面from flask import Flask, render_template import pandas as pd from sqlalchemy import create_engine app Flask(__name__) app.route(/) def show_data(): engine create_engine(sqlite:///iot_data.db) df pd.read_sql(SELECT * FROM sensor_data ORDER BY timestamp DESC LIMIT 100, engine) return render_template(dashboard.html, tables[df.to_html(classesdata)], titlesdf.columns.values) if __name__ __main__: app.run(debugTrue)对应的HTML模板templates/dashboard.html!DOCTYPE html html head title物联网数据监控/title script srchttps://cdn.plot.ly/plotly-latest.min.js/script /head body h1环境数据实时监控/h1 div idtempChart stylewidth:600px;height:250px;/div div idhumiChart stylewidth:600px;height:250px;/div script var tempData { x: {{ timestamps|safe }}, y: {{ temperatures|safe }}, type: scatter }; var humiData { x: {{ timestamps|safe }}, y: {{ humidities|safe }}, type: scatter }; Plotly.newPlot(tempChart, [tempData], {title: 温度变化曲线}); Plotly.newPlot(humiChart, [humiData], {title: 湿度变化曲线}); /script /body /html4. 单片机端程序开发4.1 传感器数据采集以STM32 HAL库为例读取SHT30温湿度传感器数据#include sht30.h #include stdio.h #define SHT30_ADDR 0x441 void SHT30_Read(float *temp, float *humi) { uint8_t cmd[2] {0x2C, 0x06}; uint8_t data[6]; HAL_I2C_Master_Transmit(hi2c1, SHT30_ADDR, cmd, 2, 100); HAL_Delay(10); HAL_I2C_Master_Receive(hi2c1, SHT30_ADDR, data, 6, 100); uint16_t temp_raw (data[0] 8) | data[1]; uint16_t humi_raw (data[3] 8) | data[4]; *temp -45 175 * (temp_raw / 65535.0); *humi 100 * (humi_raw / 65535.0); }4.2 数据格式化与发送将采集到的数据格式化为字符串并通过串口发送void Send_Sensor_Data(float temp, float humi) { char buffer[32]; sprintf(buffer, T%.1fH%.1f, temp, humi); HAL_UART_Transmit(huart1, (uint8_t*)buffer, strlen(buffer), 100); }4.3 与4G模块通信单片机通过串口向Air724UG发送AT指令void Send_AT_Command(const char *cmd) { HAL_UART_Transmit(huart2, (uint8_t*)cmd, strlen(cmd), 100); HAL_UART_Transmit(huart2, (uint8_t*)\r\n, 2, 100); } void Connect_To_Server() { Send_AT_Command(ATCGATT1); HAL_Delay(1000); Send_AT_Command(ATNETOPEN); HAL_Delay(2000); Send_AT_Command(ATCIPOPEN0,\TCP\,\192.168.1.100\,8080); HAL_Delay(3000); }5. 系统集成与调试5.1 数据流验证完整的系统数据流向如下传感器采集环境数据单片机格式化数据通过串口发送到4G模块4G模块通过TCP传输到服务器服务器解析并存储数据Web界面展示历史数据5.2 常见问题排查遇到连接问题时可以按照以下步骤检查SIM卡状态确认SIM卡已正确插入且未欠费信号强度使用ATCSQ检查数值应大于10APN配置确保与所用运营商匹配服务器连接检查服务器IP和端口是否正确确认服务器防火墙允许该端口通信在服务器使用netstat -tulnp查看端口监听状态5.3 性能优化建议数据压缩在单片机端将浮点数转换为整型减少传输量心跳机制定期发送心跳包保持TCP连接本地缓存在网络不可用时暂存数据恢复后补传睡眠模式在不采集时让模块进入低功耗状态在实际部署中我发现最影响稳定性的因素是网络信号质量。当模块处于信号边缘区域时可以尝试以下改进更换更高增益的天线调整模块位置寻找最佳信号点增加网络连接重试机制降低数据上报频率减轻网络负担

相关文章:

从零到一:用Air724UG 4G模块和Python,手把手教你搭建一个物联网数据上报系统(含完整代码)

从零构建物联网数据上报系统:Air724UG与Python实战指南 在万物互联的时代,物联网技术正悄然改变着我们的生活和工作方式。想象一下,您只需轻点手机,就能实时查看千里之外温湿度数据;或是远程监控设备运行状态&#xff…...

《流畅的Python》读书笔记03(补充02): 丰富的序列 - deque高效应对高并发序列处理

Python序列分类体系在高并发数据处理中的选型优化,需要综合考虑序列类型的内存模型、可变性、线程安全性以及操作性能。在高并发场景下,错误的选型可能导致性能瓶颈、数据竞争或内存溢出。以下是基于序列分类体系的详细选型策略与优化建议。 一、序列分类…...

生产报工软件哪个好用?工厂扫码报工神器:企丰小工单详细介绍

现在很多中小型加工厂、五金机械、汽配、组装制造工厂,还在使用纸质单据手写报工。每天员工手写工单、文员加班录表、月底核算计件工资头疼不已。不仅工序混乱、产量统计不准,还容易出现虚报产量、工序漏报、薪资对账纠纷等问题。想要数字化管理&#xf…...

告别mmWave Studio报错:手把手教你搞定AWR2243数据采集的6个常见故障

告别mmWave Studio报错:手把手教你搞定AWR2243数据采集的6个常见故障 毫米波雷达开发者在数据采集阶段常会遇到各种技术障碍。AWR2243作为工业级高频雷达模块,其配套的mmWave Studio软件在实际操作中可能出现多种报错,影响开发效率。本文将针…...

告别模型水土不服:用TENT的熵最小化,5分钟搞定测试时域自适应(附PyTorch代码)

实战TENT:5行代码解决模型部署中的“水土不服”问题 想象一下这样的场景:你花费数月训练的自动驾驶视觉模型在实验室测试中准确率高达98%,但当它遇到真实世界的暴雨天气时,识别率瞬间暴跌至60%。这种"实验室王者,…...

仅限内部团队使用的Perplexity航班缓存穿透防护策略——含Redis布隆过滤器+航班时刻表TTL动态算法

更多请点击: https://intelliparadigm.com 第一章:Perplexity航班信息查询 Perplexity 是一款以实时网络检索与引用驱动为特色的 AI 智能问答工具,其在航空旅行场景中可高效辅助用户获取最新、最准确的航班动态。不同于传统静态知识库模型&a…...

dSPACE ControlDesk实战:从虚拟CAN信号注入到动态仪表板构建

1. 虚拟CAN信号注入实战 第一次接触dSPACE ControlDesk时,最让我头疼的就是在没有实体ECU的情况下如何模拟CAN总线信号。后来发现ControlDesk自带的CAN Generator工具简直就是虚拟测试的"救命稻草"。这个工具可以完美模拟真实ECU发出的CAN信号&#xff0c…...

汇编新手避坑指南:搞懂AX、BX、CX、DX这些“双面”寄存器,才算入门

汇编新手避坑指南:搞懂AX、BX、CX、DX这些“双面”寄存器,才算入门 第一次接触汇编语言时,那些神秘的寄存器名称总让人望而生畏。尤其是AX、BX、CX、DX这几个"双面人",一会儿能拆成AH和AL,一会儿又能合体使用…...

LAV Filters深度解析:开源DirectShow媒体解码器的架构原理与性能优化指南

LAV Filters深度解析:开源DirectShow媒体解码器的架构原理与性能优化指南 【免费下载链接】LAVFilters LAV Filters - Open-Source DirectShow Media Splitter and Decoders 项目地址: https://gitcode.com/gh_mirrors/la/LAVFilters LAV Filters是一套基于F…...

照片直播如何实现?Android 通过 PTP/MTP 有线连接相机的技术方案

一、应用场景 在婚礼摄影、赛事记录、电商拍摄等业务中,客户往往希望: 摄影师按下快门,手机或平板立刻能看到照片。 常见传输方式的对比: 方式 问题 WiFi 延迟高、断连频繁 蓝牙 传输速度慢 有线 OTG ✅ 稳定、实时、低…...

拯救者工具箱终极指南:3大场景化解决方案提升笔记本使用体验

拯救者工具箱终极指南:3大场景化解决方案提升笔记本使用体验 【免费下载链接】LenovoLegionToolkit Lightweight Lenovo Vantage and Hotkeys replacement for Lenovo Legion laptops. 项目地址: https://gitcode.com/gh_mirrors/le/LenovoLegionToolkit 联想…...

一线观察:赣州新房装修公司的可靠细节

上个月,有个老朋友找我帮他参谋新房装修的事。赣州章江新区某刚交付的高端盘,精装改毛坯,180平的大户型。他跟我说,前后跑了五六家装修公司,聊完最大的感觉是——云里雾里。报价单看不懂方案,总觉得藏着坑&…...

保姆级教程:用Python脚本一键搞定OPIXray/HIXray数据集转YOLO格式(附避坑指南)

Python实战:OPIXray/HIXray数据集高效转YOLO格式全流程解析 在目标检测领域,数据格式转换往往是项目落地的第一道门槛。当我第一次拿到OPIXray和HIXray这两个专业X光安检数据集时,面对原始标注格式与YOLO训练需求的不匹配,也经历过…...

纯音乐制作难题,智能创作轻松化解

前言:音乐人的创作困境,真的太戳心了 你有没有过这样的时刻?脑子里突然冒出一段超有感觉的旋律,想把它做成完整纯音乐,却被现实难题卡住:不懂编曲,不知道怎么搭配乐器;不会用专业软…...

如何在Windows 11上免费安装安卓子系统:3步快速搭建跨平台应用中心

如何在Windows 11上免费安装安卓子系统:3步快速搭建跨平台应用中心 【免费下载链接】WSA Developer-related issues and feature requests for Windows Subsystem for Android 项目地址: https://gitcode.com/gh_mirrors/ws/WSA 想在Windows电脑上无缝运行手…...

告别手动测量!用ArcGIS+CAD搞定河道平均宽度的两种实用方法(附详细步骤)

河道平均宽度计算实战:ArcGIS与CAD高效协同方案解析 河道宽度测量是水文分析、防洪规划与生态评估中的基础工作,但传统手工测量方式在面对复杂河道形态时往往效率低下。本文将深入解析两种基于ArcGIS与CAD协同的自动化计算方法,通过技术组合实…...

深入MPSOC缓存一致性:从零配置HPC接口,让你的PL加速器告别Cache Flush

深入MPSOC缓存一致性:从零配置HPC接口,让你的PL加速器告别Cache Flush 在异构计算领域,MPSOC平台的缓存一致性配置一直是工程师面临的棘手问题。当PL端加速器通过HP接口与PS端交互时,频繁的手动缓存维护不仅增加了软件复杂度&…...

避坑指南:注册个体户时,经营范围怎么选才不影响以后开票和接项目?

技术创业者必读:个体户经营范围选择的战略与实操指南 在数字经济蓬勃发展的今天,越来越多的技术从业者选择以个体户形式开启创业之路。作为企业合法经营的"身份证",营业执照中经营范围的填写看似简单,实则暗藏玄机。一个…...

NY345固态MT29F32T08GWLBHD6-24T:B

NY345固态MT29F32T08GWLBHD6-24T:B在智能制造、交通控制、能源监测等关键领域,每一次写入与读取都决定着系统运行的可靠性。美光(Micron)MT29F32T08GWLBHD6-24T:B,以其32Tb大容量、工业级封装和多模式灵活切换,成为嵌入…...

手把手教你用VHDL在FPGA上解码IMX214 MIPI视频(基于MC20901 D-PHY,含6套工程源码)

基于VHDL的FPGA视频处理系统实战:从IMX214到高清显示 在嵌入式视觉系统开发中,FPGA因其并行处理能力和低延迟特性,成为视频采集与处理的理想平台。本文将深入探讨如何利用VHDL语言在Xilinx FPGA上构建完整的MIPI视频处理流水线,实…...

时间序列预测中的注意力剪枝技术:SPAT方法解析

1. 项目概述:当时间序列预测遇上注意力剪枝在多元时间序列预测领域,Transformer架构凭借其强大的注意力机制已成为主流解决方案。这种机制通过动态计算序列元素间的关联权重,能够有效捕捉电力负荷、交通流量等场景中的复杂时序模式。然而在实…...

百考通:AI让每一份调研与设计都高效落地

在数字化时代,市场调研、产品设计、学术研究等场景中,问卷设计作为核心环节,直接影响着数据收集的质量与工作推进的效率。传统问卷设计往往面临流程繁琐、耗时耗力、问题设计不精准等痛点,而百考通(https://www.baikao…...

渲染天空、日落与行星:给前端初学者的实时大气可视化入门指南

渲染天空、日落与行星:给前端初学者的实时大气可视化入门指南 你有没有想过,为什么浏览器里的一片蓝天看起来那么“假”?为什么游戏中的夕阳总像打了层柔光滤镜,却少了那种空气里浮动的微粒感?又或者,当你拖…...

保姆级教程:Win10/Win11下彻底解决原神启动器Qt插件初始化失败(附环境变量排查与恢复指南)

深度解析Windows环境下Qt插件初始化失败的终极解决方案 当你在Windows 10或11系统上双击原神启动器,却看到"no Qt platform plugin could be initialized"的错误提示时,那种挫败感不言而喻。这个问题看似简单,实则涉及系统环境变量…...

026 AI 漫剧工具推荐手册,附详细使用教程

2025 年,中国动画微短剧市场规模达 189.8 亿元,同比增长 276.3%,预计 2030 年将突破 850 亿元。与此同时,2026 年 AI 漫剧用户规模将从 1.2 亿飙升至 2.8 亿,市场规模有望突破 240 亿元。这一组数据有多震撼&#xff1…...

别再只看功率了!用LRS-200-24开关电源给电机供电,我踩过的这个坑你得知道

电机供电实战:LRS-200-24电源选型中那些教科书不会告诉你的细节 深夜的厂房里,两台24V直流电机突然像哮喘发作般间歇性抽搐,伴随开关电源指示灯疯狂闪烁——这个场景让现场工程师血压飙升。当教科书上的功率计算公式遭遇真实世界的电机启动电…...

别再乱用pt和px了!LaTeX排版中em、mm、pt单位选哪个?看完这篇实战避坑指南

LaTeX排版单位选择实战指南:从em到pt的精准避坑策略 当你熬夜完成的论文在导师的打印机上变成一团乱码,当精心设计的报告在不同设备上显示得七零八落——这些悲剧往往源于一个被忽视的细节:长度单位的选择。LaTeX作为科研排版的事实标准&…...

5个关键步骤掌握B站视频下载神器DownKyi:从新手到高手

5个关键步骤掌握B站视频下载神器DownKyi:从新手到高手 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#…...

Taotoken Token Plan套餐如何帮助初创团队控制AI调用成本

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Taotoken Token Plan套餐如何帮助初创团队控制AI调用成本 对于预算有限的初创团队和独立开发者而言,将大模型能力集成到…...

超导量子计算中的三量子比特门技术解析

1. 超导量子计算中的三量子比特门技术概述在量子计算领域,实现高保真度的多量子比特门操作一直是核心挑战。超导量子处理器作为当前最有前景的量子计算平台之一,其性能很大程度上取决于量子门操作的精度和效率。固定频率transmon架构因其出色的相干性和简…...