python如何读取数据时出现错误_连接数据库时出现的错误,怎样解决??

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

Traceback (most recent call last):

File "src\pymssql.pyx", line 636, in pymssql.connect

File "src\_mssql.pyx", line 1957, in _mssql.connect

File "src\_mssql.pyx", line 676, in _mssql.MSSQLConnection.__init__

File "src\_mssql.pyx", line 1683, in _mssql.maybe_raise_MSSQLDatabaseException

_mssql.MSSQLDatabaseException: (20009, b'DB-Lib error message 20009, severity 9:\nUnable to connect: Adaptive Server is unavailable or does not exist (10.103.21.34:1433)\nNet-Lib error during Unknown error (10060)\n')During handling of the above exception, another exception occurred:Traceback (most recent call last):

File "E:\python程序\连接数据库.py", line 3, in

conn=pymssql.connect(server=servername,database='xskc')

File "src\pymssql.pyx", line 642, in pymssql.connect

pymssql.OperationalError: (20009, b'DB-Lib error message 20009, severity 9:\nUnable to connect: Adaptive Server is unavailable or does not exist (10.103.21.34:1433)\nNet-Lib error during Unknown error (10060)\n')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 我可以提供一个参考示例: import pypyodbc import mysql.connector # connect to PLC plc_conn = pypyodbc.connect('DRIVER={PLC Driver};SERVER=<IP Address>;DATABASE=<Database Name>;UID=<User Name>;PWD=<Password>') # connect to MySQL mysql_conn = mysql.connector.connect(user='<MySQL User Name>', password='<MySQL Password>', host='<MySQL Host>', database='<MySQL Database>') # execute SQL query to read data from PLC sql_query = "SELECT * FROM <PLC Table Name>" cursor = plc_conn.cursor() cursor.execute(sql_query) # write the data to MySQL mysql_cursor = mysql_conn.cursor() for row in cursor.fetchall(): mysql_cursor.execute("INSERT INTO <MySQL Table Name> VALUES (%s, %s, %s)", row) # close the connections plc_conn.close() mysql_conn.commit() mysql_conn.close() ### 回答2: 使用Python可以轻松地连接PLC设备并读取数据,并将其写入MySQL数据库。以下是实现此任务的代码示例: 首先,您需要安装Python的PLC通信库,例如pyModbus或snap7。您可以使用以下命令使用pip安装它们: ``` pip install pyModbus pip install snap7 ``` 接下来,您需要安装Python的MySQL库,例如mysql-connector-python。您可以使用以下命令使用pip安装它: ``` pip install mysql-connector-python ``` 然后,您可以使用以下代码建立与PLC设备的连接,读取数据并将其写入MySQL数据库: ```python import mysql.connector from pymodbus.client.sync import ModbusTcpClient # 连接到PLC设备 plc_ip = '192.168.1.1' # 替换为实际的PLC IP地址 plc_port = 502 # 替换为实际的PLC端口号 plc = ModbusTcpClient(plc_ip, plc_port) # 连接到MySQL数据库 db_host = 'localhost' # 替换为实际的数据库主机地址 db_user = 'root' # 替换为实际的数据库用户名 db_password = 'password' # 替换为实际的数据库密码 db_name = 'test' # 替换为实际的数据库名称 db = mysql.connector.connect(host=db_host, user=db_user, password=db_password, database=db_name) cursor = db.cursor() # 读取PLC数据 slave_id = 1 # 设置PLC的从站ID register_address = 0 # 设置要读取的寄存器地址 register_count = 10 # 设置要读取的寄存器数量 response = plc.read_holding_registers(register_address, register_count, unit=slave_id) # 将数据写入MySQL数据库 if response.isError(): print("读取数据错误:{0}".format(response)) else: data = response.registers for i in range(register_count): value = data[i] sql = "INSERT INTO plc_data (value) VALUES ({0})".format(value) # 替换为实际的插入数据的SQL语句 cursor.execute(sql) db.commit() # 关闭连接 plc.close() db.close() ``` 请确保按照实际情况修改代码中的IP地址、端口号、数据库连接信息和SQL语句。此代码示例假定PLC设备使用Modbus通信协议,并且将数据写入名为"plc_data"的表中的"value"列。 注意:以上代码示例仅为参考,并且需要根据实际情况进行修改和调整。 ### 回答3: Python提供了多种与PLC通信的库,例如`pyModbusTCP`、`pyads`等。下面是一个示例代码,可用于连接PLC并读取数据,然后将数据写入MySQL数据库: ```python import pymysql from pyModbusTCP.client import ModbusClient # 连接PLC plc_ip = 'PLC的IP地址' plc_port = PLC的端口号 plc = ModbusClient(host=plc_ip, port=plc_port) if not plc.is_open(): if not plc.open(): print("无法连接到PLC") exit() # 读取PLC数据 # 此处假设要读取的数据在寄存器地址1000-1009之间,数据类型为32位无符号整数 start_address = 1000 quantity = 10 data = plc.read_holding_registers(start_address, quantity) if data: print("从PLC读取到的数据:", data) else: print("无法读取到数据") # 连接MySQL数据库 db_host = 'MySQL数据库的IP地址' db_user = 'MySQL用户名' db_password = 'MySQL密码' db_name = '数据库名称' db = pymysql.connect(host=db_host, user=db_user, password=db_password, db=db_name) # 将数据写入MySQL cursor = db.cursor() # 假设MySQL数据库中已经创建好了一个名为"plc_data"的表,表结构为(id INT AUTO_INCREMENT PRIMARY KEY, value INT) # 将读取到的PLC数据逐一插入到数据库中 for value in data: sql = "INSERT INTO plc_data (value) VALUES ({})".format(value) cursor.execute(sql) # 提交事务 db.commit() # 断开与MySQL的连接 db.close() ``` 以上代码演示了如何使用Python通过Modbus通信协议连接到PLC并读取数据,然后使用pymysql库连接到MySQL数据库,并将数据写入数据库中。请注意,需要根据实际情况修改连接PLC和数据库的相关参数,并确保PLC和MySQL数据库的可访问性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值