【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()
相关推荐
IT培训中心-竺老师1 分钟前
Oracle 23AI创建示例库
数据库·oracle
小白学大数据20 分钟前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
time never ceases41 分钟前
使用docker方式进行Oracle数据库的物理迁移(helowin/oracle_11g)
数据库·docker·oracle
Frank牛蛙44 分钟前
1.每日SQL----2024/11/7
数据库·sql
Ciderw1 小时前
块存储、文件存储和对象存储详细介绍
网络·数据库·nvme·对象存储·存储·块存储·文件存储
薛晓刚1 小时前
数据库优化指南:如何将基本功能运用到极致?
数据库
stars_User1 小时前
MySQL数据库面试题(下)
数据库·mysql
未来之窗软件服务1 小时前
sql速度优化多条合并为一条语句
数据库
山东布谷科技官方1 小时前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
易云码2 小时前
信息安全建设方案,网络安全等保测评方案,等保技术解决方案,等保总体实施方案(Word原件)
数据库·物联网·安全·web安全·低代码