【Pyhton】读取寄存器数据到MySQL数据库

目录

步骤

modsim32软件配置

[Navicat for MySQL](#Navicat for MySQL)

代码实现


步骤

  1. 安装必要的库 :确保安装了pymodbuspymysql

  2. 配置Modbus连接:设置Modbus从站的IP地址、端口(对于TCP)或串行通信参数(对于RTU)。

  3. 连接MySQL数据库:设置数据库的连接参数,如主机名、用户名、密码和数据库名。

  4. 读取Modbus寄存器 :使用pymodbus客户端从Modbus从站读取寄存器数据。

  5. 写入MySQL数据库:将读取的数据插入到MySQL数据库的表中。

  6. 错误处理:添加错误处理逻辑以处理连接失败、读取错误等。

  7. 资源管理:确保在结束时关闭Modbus客户端和MySQL连接。

modsim32软件配置

Navicat for MySQL 是一套管理和开发 MySQL 的理想解决方案,Navicat 为数据库管理、开发和维护提供了直观而强大的图形界面,给 MySQL 新手以及专业人士提供了一组全面的工具。Navicat for MySQL 主要功能包括 SQL 创建工具或编辑器、数据模型工具、数据传输、导入或导出、数据或结构同步、报表等

代码实现

复制代码
from pymodbus.client import ModbusTcpClient as ModbusClient
import pymysql
import time

# 定义Modbus TCP从站地址和端口号
address = '127.0.0.1'
port = 502

# 定义MySQL数据库连接参数
host = "localhost"
user = "root"
password = "root"
database = "test"

# 建立Modbus TCP连接和MySQL数据库连接
client = ModbusClient(address, port=port)
client.connect()
cnx = pymysql.connect(user='root', password='101900', host='localhost', database='pyqt')
cursor = cnx.cursor()
# 创建表格
cursor.execute("DROP TABLE IF EXISTS sensor_data") # 如果存在表则重新创建
createTab = """CREATE TABLE sensor_data( # 创建表
     id INTEGER PRIMARY KEY AUTO_INCREMENT,
     TIME CHAR(50),
     temperature CHAR(50),
     voltage CHAR(50),
     current CHAR(50),
    resistance CHAR(50) )"""
cursor.execute(createTab) # 执行数据库语句

while True:
     localtime = time.asctime(time.localtime(time.time())) # time包操作,打印本地时间
     local_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) # 规整本地时间的格式
     # 读取Modbus TCP从站寄存器中的数据
     result = client.read_holding_registers(address=0, count=4, unit=1)
     data = {
         'TIME': local_time,
         'temperature': result.registers[0],
         'voltage': result.registers[1],
         'current': result.registers[2],
         'resistance': result.registers[3]
         }
     
     # 将数据写入到MySQL数据库中
     add_data = ("INSERT INTO sensor_data "
     "(TIME,temperature, voltage, current, resistance) "
     "VALUES (%(TIME)s,%(temperature)s, %(voltage)s, %(current)s, %(resistance)s)")
     cursor.execute(add_data, data)
     cnx.commit()

      # 模拟每隔1秒钟读取一次数据
     time.sleep(1)

# 关闭Modbus TCP连接和MySQL数据库连接
client.close()
cursor.close()
cnx.close()
相关推荐
Geoffwo1 分钟前
Oracle MySQL8.0升级8.4,无感升级数据库
数据库·oracle
u0110225123 分钟前
如何自定义查询历史记录面板的展示风格_时间轴样式设计
jvm·数据库·python
2301_769340675 分钟前
HTML怎么实现快捷跳转顶部_HTML固定悬浮锚点按钮【介绍】
jvm·数据库·python
m0_6091604917 分钟前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
呼Lu噜19 分钟前
基于C#的ASP.NET Core中分析async、await的使用场景
数据库·c#·asp.net
李白的天不白20 分钟前
大规模请求数据并发问题
java·前端·数据库
zjy2777724 分钟前
Golang bcrypt如何加密密码_Golang密码加密教程【收藏】
jvm·数据库·python
万邦科技Lafite30 分钟前
API接口一键获取商品评论,根据商品评论分析客户画像
linux·服务器·数据库·windows·microsoft·电商开放平台
phltxy33 分钟前
Redis 核心数据类型之 String 详解
数据库·redis·bootstrap
老纪38 分钟前
Redis怎样利用Lua为多个Key同步续期
jvm·数据库·python