加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴散
  • 作品版權(quán)保護
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入

鋇錸技術(shù)PLC網(wǎng)關(guān)采集設(shè)備數(shù)據(jù)Python寫入數(shù)據(jù)庫

2023/09/13
3370
服務(wù)支持:
技術(shù)交流群

完成交易后在“購買成功”頁面掃碼入群,即可與技術(shù)大咖們分享疑惑和經(jīng)驗、收獲成長和認同、領(lǐng)取優(yōu)惠和紅包等。

虛擬商品不可退

當前內(nèi)容為數(shù)字版權(quán)作品,購買后不支持退換且無法轉(zhuǎn)移使用。

加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論
放大
實物圖
  • 方案介紹
    • 1、Modbus slave設(shè)置從機Modbus TCP參數(shù)
    • 2、設(shè)置BL102將Modbus slave從機數(shù)據(jù)點映射
    • 3、MQTT客戶端設(shè)置訂閱
    • 客戶端設(shè)置連接MQTT服務(wù)器參數(shù)
    • 4、Python采集并寫入數(shù)據(jù)庫
  • 相關(guān)文件
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

1、Modbus slave設(shè)置從機Modbus TCP參數(shù)

設(shè)置Modbus TCP協(xié)議和地址

模擬軟件設(shè)置的是 當前電腦的,所以后面 配置Modbus TCP的從機時,就要填當前電腦的ip地址,不要寫 bl系列設(shè)備的ip地址

設(shè)置數(shù)據(jù)參數(shù)

設(shè)備地址:22

功能碼:04

數(shù)據(jù)類型:16

起始地址:0

數(shù)量:5個

2、設(shè)置BL102將Modbus slave從機數(shù)據(jù)點映射

設(shè)置WAN口為Modbus TCP Master模式

設(shè)置bl102設(shè)備和從機同個網(wǎng)段

添加從機

從機的ip地址,需要填寫Modbus slave軟件的所在電腦的ip地址,不要填了 bl網(wǎng)關(guān)的ip地址

添加數(shù)據(jù)點

設(shè)置MQTT broker(MQTT服務(wù)器)信息

查看設(shè)備上下行狀態(tài)

查看下行連接設(shè)備和上行連接MQTT服務(wù)器狀態(tài)

3、MQTT客戶端設(shè)置訂閱

客戶端設(shè)置連接MQTT服務(wù)器參數(shù)

服務(wù)器ip、端口、ID、心跳等。

設(shè)置訂閱BL102設(shè)備的主題

剛才設(shè)置BL102設(shè)備的發(fā)布主題是 test,那么訂閱也是 test

查看已收到BL102設(shè)備的數(shù)據(jù)

4、Python采集并寫入數(shù)據(jù)庫

# python3.6
import json
import sqlite3

import random
from datetime import datetime

from paho.mqtt import client as mqtt_client

broker = '192.168.1.165'
#broker = 'broker-cn.emqx.io'
port = 1883
topic = "test"
# generate client ID with pub prefix randomly
client_id = f'python-mqtt-{random.randint(0, 100)}'

def connect_mqtt() -> mqtt_client:
def on_connect(client, userdata, flags, rc):
if rc == 0:
print("Connected to MQTT Broker!")
else:
print("Failed to connect, return code %dn", rc)

client = mqtt_client.Client(client_id)
client.on_connect = on_connect
client.connect(broker, port)
return client

#將數(shù)據(jù)出入數(shù)據(jù)庫
def create_table():
#連接數(shù)據(jù)庫,沒有則創(chuàng)建
conn = sqlite3.connect('plcdata')
print('連接數(shù)據(jù)庫成功')

#判斷iot表是否存在,不存在則新建。 CREATE TABLE IF NOT EXISTS iot
try:
create_tb_cmd='''
CREATE TABLE IF NOT EXISTS iot
(lat TEXT,
lng TEXT,
signal_strength INT,
REG001 INT,
REG002 INT,
REG003 INT,
REG004 INT,
REG005 INT);
'''
#執(zhí)行創(chuàng)建數(shù)據(jù)表語句
conn.execute(create_tb_cmd)
except:
print("Create table failed")
return False

insert_dt_cmd='INSERT INTO iot (lat,lng,signal_strength,REG001,REG002,REG003,REG004,REG005) VALUES '+ strlist + ';'
print(insert_dt_cmd)
# insert_dt_cmd='''
# INSERT INTO iot (lat,lng,signal_strength,REG001,REG002,REG003,REG004,REG005) VALUES (0.000000,0.000000,0,33,8538,234,22,9046);
# '''

conn.execute(insert_dt_cmd)
print('寫入數(shù)據(jù)庫成功')
conn.commit()
conn.close()

strlist = ''
def subscribe(client: mqtt_client):
def on_message(client, userdata, msg):
t = datetime.now()
print('當前時間:',t)
#print(f"Received `{msg.payload.decode()}` from `{msg.topic}` topic")
json_data = msg.payload.decode() #解析訂閱主題信息,
# print(type(json_data)) #判斷data類型,是json字符串
dict_json = json.loads(json_data)
#print(type(dict_json))
#print(dict_json)

sensordatas = dict_json['sensorDatas']
list_data =[]
for i in sensordatas:
#print(type(i),i)
#print(i['flag'],type(i['flag']))

if i['flag'] == 'GPS':
list_data.append(i['lat'])
list_data.append(i['lng'])
#print(list_data)

else:
#print(i['flag'],i['value'])
list_data.append(i['value'])
#print(list_data)
global strlist
strlist = str(tuple(list_data))
print(strlist)
create_table()

client.subscribe(topic)
client.on_message = on_message

def run():
client = connect_mqtt()
subscribe(client)
client.loop_forever()

if __name__ == '__main__':
run()

其他:python發(fā)布和訂閱
發(fā)布

# python 3.6

import random
import time

from paho.mqtt import client as mqtt_client

broker = '192.168.1.165'
port = 1883
topic = "test"
# generate client ID with pub prefix randomly
client_id = f'python-mqtt-{random.randint(0, 1000)}'

def connect_mqtt():
def on_connect(client, userdata, flags, rc):
if rc == 0:
print("Connected to MQTT Broker!")
else:
print("Failed to connect, return code %dn", rc)

client = mqtt_client.Client(client_id)
client.on_connect = on_connect
client.connect(broker, port)
return client

def publish(client):
msg_count = 0
while True:
time.sleep(1)
msg = f"messages: {msg_count}"
result = client.publish(topic, msg)
# result: [0, 1]
status = result[0]
if status == 0:
print(f"Send `{msg}` to topic `{topic}`")
else:
print(f"Failed to send message to topic {topic}")
msg_count += 1

def run():
client = connect_mqtt()
client.loop_start()
publish(client)

if __name__ == '__main__':
run()

訂閱

# python3.6

import random
from datetime import datetime

from paho.mqtt import client as mqtt_client

broker = '192.168.1.165'
#broker = 'broker-cn.emqx.io'
port = 1883
topic = "test"
# generate client ID with pub prefix randomly
client_id = f'python-mqtt-{random.randint(0, 100)}'

def connect_mqtt() -> mqtt_client:
def on_connect(client, userdata, flags, rc):
if rc == 0:
print("Connected to MQTT Broker!")
else:
print("Failed to connect, return code %dn", rc)

client = mqtt_client.Client(client_id)
client.on_connect = on_connect
client.connect(broker, port)
return client

def subscribe(client: mqtt_client):
def on_message(client, userdata, msg):
t = datetime.now()
print('當前時間:',t)
print(f"Received `{msg.payload.decode()}` from `{msg.topic}` topic")

client.subscribe(topic)
client.on_message = on_message

def run():
client = connect_mqtt()
subscribe(client)
client.loop_forever()

if __name__ == '__main__':
run()

  • 鋇錸技術(shù)PLC網(wǎng)關(guān)采集設(shè)備數(shù)據(jù)Python寫入數(shù)據(jù)庫.docx

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風險等級 參考價格 更多信息
CC430F5137IRGZR 1 Texas Instruments 16-Bit ultra-low-power CC430 Sub 1 GHz wireless MCU with 12-Bit ADC, 32kB Flash and 4kB RAM 48-VQFN -40 to 85

ECAD模型

下載ECAD模型
$7.8 查看
KSZ8463RLI 1 Microchip Technology Inc DATACOM, MANCHESTER ENCODER

ECAD模型

下載ECAD模型
$8.15 查看
AD73311ARSZ-REEL 1 Rochester Electronics LLC SPECIALTY TELECOM CIRCUIT, PDSO20, SSOP-20
$9.29 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

深圳市鋇錸技術(shù)有限公司是一家高新技術(shù)企業(yè),專注工業(yè)邊緣計算網(wǎng)關(guān)、PLC網(wǎng)關(guān)、Modbus網(wǎng)關(guān)、MQTT網(wǎng)關(guān)、OPC網(wǎng)關(guān)、4G工業(yè)邊緣路由器、工業(yè)物聯(lián)網(wǎng)關(guān)、工業(yè)以太網(wǎng)IO模塊、工業(yè)物聯(lián)網(wǎng)邊緣控制器等產(chǎn)品研發(fā)與制造,立志成為令人尊敬的工業(yè)物聯(lián)網(wǎng)與邊緣計算設(shè)備制造商。