generated from zhangwei/Train_Identify
Compare commits
4 Commits
Author | SHA1 | Date |
---|---|---|
|
23d0de4e38 | |
|
3d4b918a93 | |
|
7108d4e85b | |
|
67f829258c |
|
@ -9,7 +9,27 @@ a = Analysis(
|
||||||
pathex=[],
|
pathex=[],
|
||||||
binaries=[],
|
binaries=[],
|
||||||
datas=[],
|
datas=[],
|
||||||
hiddenimports=[],
|
hiddenimports=[
|
||||||
|
'engineio.async_drivers.eventlet',
|
||||||
|
'eventlet.hubs.epolls',
|
||||||
|
'eventlet.hubs.kqueue',
|
||||||
|
'eventlet.hubs.selects',
|
||||||
|
'dns',
|
||||||
|
'dns.dnssec',
|
||||||
|
'dns.e164',
|
||||||
|
'dns.hash',
|
||||||
|
'dns.namedict',
|
||||||
|
'dns.tsigkeyring',
|
||||||
|
'dns.update',
|
||||||
|
'dns.version',
|
||||||
|
'dns.zone',
|
||||||
|
'dns.asyncbackend',
|
||||||
|
'dns.asyncquery',
|
||||||
|
'dns.asyncresolver',
|
||||||
|
'dns.versioned',
|
||||||
|
'socketserver',
|
||||||
|
'http.server'
|
||||||
|
],
|
||||||
hookspath=[],
|
hookspath=[],
|
||||||
hooksconfig={},
|
hooksconfig={},
|
||||||
runtime_hooks=[],
|
runtime_hooks=[],
|
||||||
|
|
11
app.py
11
app.py
|
@ -313,6 +313,16 @@ def runReadPLC():
|
||||||
logger.error("数据 读取&上传 异常:%s", traceback.print_exc())
|
logger.error("数据 读取&上传 异常:%s", traceback.print_exc())
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
def writePLC_heartbeat():
|
||||||
|
while True:
|
||||||
|
try:
|
||||||
|
detect.writePLC_heartbeat()
|
||||||
|
except Exception as e:
|
||||||
|
logger.error("心跳(PLC时间读取)数据 读取&上传 异常:%s", traceback.print_exc())
|
||||||
|
continue
|
||||||
|
finally:
|
||||||
|
time.sleep(30)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
# --- 运行方式一 ---
|
# --- 运行方式一 ---
|
||||||
|
@ -327,6 +337,7 @@ if __name__ == '__main__':
|
||||||
pool = eventlet.GreenPool()
|
pool = eventlet.GreenPool()
|
||||||
pool.spawn_n(runWebSocket)
|
pool.spawn_n(runWebSocket)
|
||||||
pool.spawn_n(runReadPLC)
|
pool.spawn_n(runReadPLC)
|
||||||
|
pool.spawn_n(writePLC_heartbeat)
|
||||||
pool.waitall()
|
pool.waitall()
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -4,17 +4,17 @@ track_num = 2
|
||||||
|
|
||||||
[log]
|
[log]
|
||||||
log_path = ./logs
|
log_path = ./logs
|
||||||
stdout_log_level = INFO
|
stdout_log_level = DEBUG
|
||||||
file_log_level = INFO
|
file_log_level = DEBUG
|
||||||
|
|
||||||
[plc]
|
[plc]
|
||||||
ip_address = 10.227.181.106
|
ip_address = 192.168.1.150
|
||||||
slot = 0
|
slot = 0
|
||||||
timeout = 0.9
|
timeout = 0.9
|
||||||
interval_plc = 6000
|
interval_plc = 2000
|
||||||
|
|
||||||
[upload]
|
[upload]
|
||||||
upload_type = 1
|
upload_type = 0
|
||||||
login_web_url = http://192.168.2.167:20004/api/blade-auth/oauth/token
|
login_web_url = http://192.168.2.167:20004/api/blade-auth/oauth/token
|
||||||
upload_pinch_coal_url = http://xxxx
|
upload_pinch_coal_url = http://xxxx
|
||||||
upload_gross_weight_url = http://xxxx
|
upload_gross_weight_url = http://xxxx
|
||||||
|
|
|
@ -2,7 +2,8 @@ import time
|
||||||
|
|
||||||
from service.interfaceToWeb import interfaceToWeb
|
from service.interfaceToWeb import interfaceToWeb
|
||||||
from service.TagsList import TagsList, plc_info
|
from service.TagsList import TagsList, plc_info
|
||||||
from utils.Tool import logger, config, PLC_Tool
|
from utils.Tool import logger, config, PLC_Tool, g_read_plc, g_write_plc
|
||||||
|
|
||||||
|
|
||||||
plcInfo = plc_info()
|
plcInfo = plc_info()
|
||||||
|
|
||||||
|
@ -20,9 +21,9 @@ def writePLC(ip: str, slot: int = 0, tags=None):
|
||||||
if len(tags) < 1:
|
if len(tags) < 1:
|
||||||
return False, "参数tags未写入需要修改的标签点位"
|
return False, "参数tags未写入需要修改的标签点位"
|
||||||
|
|
||||||
plc = PLC_Tool(ip, slot)
|
# plc = PLC_Tool(ip, slot)
|
||||||
|
|
||||||
plc.batch_write_tag(tags)
|
g_read_plc.batch_write_tag(tags)
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
@ -69,7 +70,7 @@ def read_loading_tags(tagsList, plc):
|
||||||
# 开始配煤时,记录标志,准备读取掐煤量
|
# 开始配煤时,记录标志,准备读取掐煤量
|
||||||
# 注意:此处之前用 completion_coal_blending_type 从true变为false判断该读掐煤量,后发现PLC在点击“配煤重读”时,此值不准确跳动
|
# 注意:此处之前用 completion_coal_blending_type 从true变为false判断该读掐煤量,后发现PLC在点击“配煤重读”时,此值不准确跳动
|
||||||
# 故 改为 start_coal_blending_type 从false变为true时读取;效果会比前者稍慢
|
# 故 改为 start_coal_blending_type 从false变为true时读取;效果会比前者稍慢
|
||||||
if loadingTagsNamelist[index] == "start_coal_blending_type" \
|
if loadingTagsNamelist[index] == "completion_coal_blending_type" \
|
||||||
and len(plcInfo.loadingDict_List) > track \
|
and len(plcInfo.loadingDict_List) > track \
|
||||||
and loadingTagsNamelist[index] in plcInfo.loadingDict_List[track].keys() \
|
and loadingTagsNamelist[index] in plcInfo.loadingDict_List[track].keys() \
|
||||||
and plcInfo.loadingDict_List[track][loadingTagsNamelist[index]] != tag["value"] \
|
and plcInfo.loadingDict_List[track][loadingTagsNamelist[index]] != tag["value"] \
|
||||||
|
@ -252,28 +253,41 @@ def upload_load_type(loadingDict: dict):
|
||||||
else:
|
else:
|
||||||
return -1, ""
|
return -1, ""
|
||||||
|
|
||||||
|
def writePLC_heartbeat():
|
||||||
|
global g_write_plc
|
||||||
|
if g_write_plc is None:
|
||||||
|
g_write_plc = PLC_Tool(config.ip_address, config.slot)
|
||||||
|
g_write_plc.get_plc_time()
|
||||||
|
|
||||||
def interval_read_PLC_up_web():
|
def interval_read_PLC_up_web():
|
||||||
"""
|
"""
|
||||||
循环读取PLC数据 根据条件上传至WEB
|
循环读取PLC数据 根据条件上传至WEB
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
plc = PLC_Tool(config.ip_address, config.slot)
|
global g_read_plc
|
||||||
|
if g_read_plc is None:
|
||||||
|
g_read_plc = PLC_Tool(config.ip_address, config.slot)
|
||||||
|
|
||||||
interface = interfaceToWeb()
|
interface = interfaceToWeb()
|
||||||
login_result, token_type, access_token = interface.loginWeb(config.login_web_url, config.username,
|
|
||||||
|
login_result = ""
|
||||||
|
token_type = ""
|
||||||
|
access_token = ""
|
||||||
|
if config.upload_type == 1:
|
||||||
|
login_result, token_type, access_token = interface.loginWeb(config.login_web_url, config.username,
|
||||||
config.password, config.authorization)
|
config.password, config.authorization)
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
up_result = ""
|
up_result = ""
|
||||||
start_time = time.time()
|
start_time = time.time()
|
||||||
load_result, flag_changeds = readPLC(plc)
|
load_result, flag_changeds = readPLC(g_read_plc)
|
||||||
end_time = time.time()
|
end_time = time.time()
|
||||||
# print(end_time, "运行时长:%3.f \n" % (end_time - start_time))
|
# print(end_time, "运行时长:%3.f \n" % (end_time - start_time))
|
||||||
if not load_result:
|
if not load_result:
|
||||||
time.sleep(30)
|
time.sleep(4)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if login_result is not "":
|
if config.upload_type == 1 and login_result is not "":
|
||||||
logger.warn(login_result)
|
logger.warn(login_result)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
@ -363,7 +377,7 @@ def interval_read_PLC_up_web():
|
||||||
(track+1), loadingDict["loading_carriage_order"],
|
(track+1), loadingDict["loading_carriage_order"],
|
||||||
loadingDict.get("gross_weight_refresh", 0)))
|
loadingDict.get("gross_weight_refresh", 0)))
|
||||||
|
|
||||||
plc = PLC_Tool(config.ip_address, config.slot)
|
# plc = PLC_Tool(config.ip_address, config.slot)
|
||||||
|
|
||||||
grossrefresh_Tag = ""
|
grossrefresh_Tag = ""
|
||||||
for grossrefresh_l in TagsList().getLoading_Tags()[track]:
|
for grossrefresh_l in TagsList().getLoading_Tags()[track]:
|
||||||
|
@ -371,7 +385,7 @@ def interval_read_PLC_up_web():
|
||||||
grossrefresh_Tag = grossrefresh_l[1]
|
grossrefresh_Tag = grossrefresh_l[1]
|
||||||
if grossrefresh_Tag == "":
|
if grossrefresh_Tag == "":
|
||||||
logger.error("股道%d- 配煤重读点位读取失败 !!!", (track + 1))
|
logger.error("股道%d- 配煤重读点位读取失败 !!!", (track + 1))
|
||||||
success, msg = plc.write_tag(grossrefresh_Tag, 0)
|
success, msg = g_read_plc.write_tag(grossrefresh_Tag, 0)
|
||||||
|
|
||||||
if not success:
|
if not success:
|
||||||
logger.error("股道%d- 配煤重读归零失败 !!!", (track+1))
|
logger.error("股道%d- 配煤重读归零失败 !!!", (track+1))
|
||||||
|
@ -458,18 +472,24 @@ def report_open(pound_no: str, total_number_carriage: int, pre_load: list):
|
||||||
elif tag_list[0] == "total_number_carriage":
|
elif tag_list[0] == "total_number_carriage":
|
||||||
total_number_carriage_tag = tag_list[1]
|
total_number_carriage_tag = tag_list[1]
|
||||||
|
|
||||||
plc = PLC_Tool(config.ip_address, config.slot)
|
global g_write_plc
|
||||||
|
if g_write_plc is None:
|
||||||
|
g_write_plc = PLC_Tool(config.ip_address, config.slot)
|
||||||
|
if len(plcInfo.loadingDict_List) < 1:
|
||||||
|
return 500, "尚未成功读取到PLC的数据,请确认PLC链接是否正常", {}
|
||||||
|
|
||||||
if "report_open_type" in plcInfo.loadingDict_List[pound_no-1].keys() and plcInfo.loadingDict_List[pound_no-1]["report_open_type"] == 1:
|
if "report_open_type" in plcInfo.loadingDict_List[pound_no-1].keys() and plcInfo.loadingDict_List[pound_no-1]["report_open_type"] == 1:
|
||||||
over_write = True
|
over_write = True
|
||||||
old_total_number_carriage = plcInfo.loadingDict_List[pound_no-1]["total_number_carriage"]
|
old_total_number_carriage = plcInfo.loadingDict_List[pound_no-1]["total_number_carriage"]
|
||||||
|
|
||||||
success, msg, tags_value = plc.get_array(tagsList.getPreLoadWeight_Tags()[pound_no-1][1], tagsList.getPreLoadWeight_Tags()[pound_no-1][3])
|
logger.info(tagsList.getPreLoadWeight_Tags()[pound_no-1][3])
|
||||||
|
success, msg, tags_value = g_write_plc.get_array(tagsList.getPreLoadWeight_Tags()[pound_no-1][1], int(tagsList.getPreLoadWeight_Tags()[pound_no-1][3]))
|
||||||
|
|
||||||
if success:
|
if success:
|
||||||
old_pre_load = tags_value["value"]
|
old_pre_load = tags_value["value"]
|
||||||
|
|
||||||
success, msg, results = \
|
success, msg, results = \
|
||||||
plc.batch_write_tag([(report_open_type_tag, 1),
|
g_write_plc.batch_write_tag([(report_open_type_tag, 1),
|
||||||
(total_number_carriage_tag, total_number_carriage)])
|
(total_number_carriage_tag, total_number_carriage)])
|
||||||
|
|
||||||
if not success:
|
if not success:
|
||||||
|
@ -484,7 +504,7 @@ def report_open(pound_no: str, total_number_carriage: int, pre_load: list):
|
||||||
pre_load.insert(0, 0.0)
|
pre_load.insert(0, 0.0)
|
||||||
logger.info("股道%d- 总车节数:%d 上传预装量:%s", pound_no, total_number_carriage, str(pre_load))
|
logger.info("股道%d- 总车节数:%d 上传预装量:%s", pound_no, total_number_carriage, str(pre_load))
|
||||||
|
|
||||||
success, msg = plc.write_array("AI.load", pre_load)
|
success, msg = g_write_plc.write_array("AI.load", pre_load)
|
||||||
if not success:
|
if not success:
|
||||||
return 412, msg, {}
|
return 412, msg, {}
|
||||||
|
|
||||||
|
@ -548,8 +568,10 @@ def report_close(pound_no: str, total_number_carriage: int):
|
||||||
if len(pre_load_tags_list) < (pound_no - 1):
|
if len(pre_load_tags_list) < (pound_no - 1):
|
||||||
return 412, "股道“预装量”的点位配置未读到,请检查配置文件", {}
|
return 412, "股道“预装量”的点位配置未读到,请检查配置文件", {}
|
||||||
|
|
||||||
plc = PLC_Tool(config.ip_address, config.slot)
|
global g_write_plc
|
||||||
success, msg, results = plc.batch_write_tag([(open_report_tags_list[pound_no - 1], 0),
|
if g_write_plc is None:
|
||||||
|
g_write_plc= PLC_Tool(config.ip_address, config.slot)
|
||||||
|
success, msg, results = g_write_plc.batch_write_tag([(open_report_tags_list[pound_no - 1], 0),
|
||||||
(total_number_carriage_tags_list[pound_no - 1], 0)])
|
(total_number_carriage_tags_list[pound_no - 1], 0)])
|
||||||
if not success:
|
if not success:
|
||||||
return 412, msg, {}
|
return 412, msg, {}
|
||||||
|
@ -560,7 +582,7 @@ def report_close(pound_no: str, total_number_carriage: int):
|
||||||
# return responseMsg(200, msg, results)
|
# return responseMsg(200, msg, results)
|
||||||
|
|
||||||
pre_load = [0] * config.carriage_num_max
|
pre_load = [0] * config.carriage_num_max
|
||||||
success, msg = plc.write_array(pre_load_tags_list[pound_no - 1], pre_load)
|
success, msg = g_write_plc.write_array(pre_load_tags_list[pound_no - 1], pre_load)
|
||||||
if not success:
|
if not success:
|
||||||
return 412, msg, {}
|
return 412, msg, {}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ class interfaceToWeb:
|
||||||
"grant_type": "password"}
|
"grant_type": "password"}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
res = requests.post(url=url, headers=headers, data=data)
|
res = requests.post(url=url, headers=headers, data=data, timeout=1)
|
||||||
|
|
||||||
if res.status_code == requests.codes.ok:
|
if res.status_code == requests.codes.ok:
|
||||||
jsonData = json.loads(res.text)
|
jsonData = json.loads(res.text)
|
||||||
|
@ -68,7 +68,7 @@ class interfaceToWeb:
|
||||||
"poundNo": track_name}
|
"poundNo": track_name}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
res = requests.post(url=url, headers=headers, json=data)
|
res = requests.post(url=url, headers=headers, json=data, timeout=1)
|
||||||
|
|
||||||
if res.status_code == requests.codes.ok:
|
if res.status_code == requests.codes.ok:
|
||||||
jsonData = json.loads(res.text)
|
jsonData = json.loads(res.text)
|
||||||
|
@ -108,7 +108,7 @@ class interfaceToWeb:
|
||||||
"houseStatus": 4,
|
"houseStatus": 4,
|
||||||
"poundNo": track_name}
|
"poundNo": track_name}
|
||||||
try:
|
try:
|
||||||
res = requests.post(url=url, headers=headers, json=data)
|
res = requests.post(url=url, headers=headers, json=data, timeout=1)
|
||||||
|
|
||||||
if res.status_code == requests.codes.ok:
|
if res.status_code == requests.codes.ok:
|
||||||
jsonData = json.loads(res.text)
|
jsonData = json.loads(res.text)
|
||||||
|
@ -145,7 +145,7 @@ class interfaceToWeb:
|
||||||
"houseStatus": house_status,
|
"houseStatus": house_status,
|
||||||
"poundNo": track_name}
|
"poundNo": track_name}
|
||||||
try:
|
try:
|
||||||
res = requests.post(url=url, headers=headers, json=data)
|
res = requests.post(url=url, headers=headers, json=data, timeout=1)
|
||||||
|
|
||||||
if res.status_code == requests.codes.ok:
|
if res.status_code == requests.codes.ok:
|
||||||
jsonData = json.loads(res.text)
|
jsonData = json.loads(res.text)
|
||||||
|
@ -172,7 +172,7 @@ class interfaceToWeb:
|
||||||
"""
|
"""
|
||||||
headers = {'Content-Type': 'application/json', 'blade-auth': self.token}
|
headers = {'Content-Type': 'application/json', 'blade-auth': self.token}
|
||||||
try:
|
try:
|
||||||
res = requests.post(url=url, headers=headers, json=data)
|
res = requests.post(url=url, headers=headers, json=data, timeout=1)
|
||||||
|
|
||||||
if res.status_code == requests.codes.ok:
|
if res.status_code == requests.codes.ok:
|
||||||
jsonData = json.loads(res.text)
|
jsonData = json.loads(res.text)
|
||||||
|
|
|
@ -8,19 +8,20 @@ logger = Log(stdout_log_level=logging.FATAL,
|
||||||
fil_log_level=logging.FATAL).getLogger()
|
fil_log_level=logging.FATAL).getLogger()
|
||||||
|
|
||||||
class PLC_Tool:
|
class PLC_Tool:
|
||||||
def __init__(self, plcIp: str, plcSlot: int = 0, timeOut: float = 1):
|
def __init__(self, plcIp: str, plcSlot: int = 0, timeOut: float = 2):
|
||||||
self.plcIp = plcIp
|
self.plcIp = plcIp
|
||||||
self.plcSlot = plcSlot
|
self.plcSlot = plcSlot
|
||||||
self.timeOut = timeOut
|
self.timeOut = timeOut
|
||||||
self.comm = None
|
self.comm = None
|
||||||
logger.info("准备连接PLC,IP:%s, slot: %d, timeout: %d", self.plcIp, self.plcSlot, self.timeOut)
|
logger.debug("准备连接PLC,IP:%s, slot: %d, timeout: %d", self.plcIp, self.plcSlot, self.timeOut)
|
||||||
self.comm = PLC(self.plcIp, self.plcSlot, self.timeOut)
|
self.comm = PLC(self.plcIp, self.plcSlot, self.timeOut)
|
||||||
logger.info("连接PLC成功")
|
|
||||||
|
self.comm.ConnectionSize = 504
|
||||||
|
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
logger.info("准备断开PLC连接")
|
logger.debug("准备断开PLC连接")
|
||||||
self.comm.Close()
|
self.comm.Close()
|
||||||
logger.info("断开PLC连接完成")
|
logger.debug("断开PLC连接完成")
|
||||||
|
|
||||||
def __isIP(self, ip: str):
|
def __isIP(self, ip: str):
|
||||||
"""
|
"""
|
||||||
|
@ -37,12 +38,15 @@ class PLC_Tool:
|
||||||
def connect(self):
|
def connect(self):
|
||||||
logger.warning("准备重新连接PLC")
|
logger.warning("准备重新连接PLC")
|
||||||
self.comm = PLC(self.plcIp, self.plcSlot, self.timeOut)
|
self.comm = PLC(self.plcIp, self.plcSlot, self.timeOut)
|
||||||
logger.info("连接PLC成功")
|
self.comm.ConnectionSize = 504
|
||||||
|
|
||||||
def close(self):
|
def close(self):
|
||||||
logger.info("准备断开PLC连接")
|
logger.debug("准备断开PLC连接")
|
||||||
self.comm.Close()
|
self.comm.Close()
|
||||||
logger.info("断开PLC连接完成")
|
logger.debug("断开PLC连接完成")
|
||||||
|
|
||||||
|
def is_connected(self):
|
||||||
|
return self.comm.conn.SocketConnected
|
||||||
|
|
||||||
def batch_write_tag(self, tags: list):
|
def batch_write_tag(self, tags: list):
|
||||||
"""
|
"""
|
||||||
|
@ -67,7 +71,7 @@ class PLC_Tool:
|
||||||
return 0, "输入的参数格式不对,请参照:[(\"AI.speed\", 10.32),(\"AI.start\", 1)]", None
|
return 0, "输入的参数格式不对,请参照:[(\"AI.speed\", 10.32),(\"AI.start\", 1)]", None
|
||||||
|
|
||||||
# print("准备写入PLC的数据:%s" % str(tags))
|
# print("准备写入PLC的数据:%s" % str(tags))
|
||||||
logger.info("准备写入PLC的数据:%s", str(tags))
|
logger.debug("准备写入PLC的数据:%s", str(tags))
|
||||||
rets = self.comm.Write(tags)
|
rets = self.comm.Write(tags)
|
||||||
|
|
||||||
hasNone = False
|
hasNone = False
|
||||||
|
@ -84,7 +88,7 @@ class PLC_Tool:
|
||||||
logger.warning("写入PLC的数据中,存在部分失败:%s", str(results))
|
logger.warning("写入PLC的数据中,存在部分失败:%s", str(results))
|
||||||
return 2, "存在写入失败的标签", results
|
return 2, "存在写入失败的标签", results
|
||||||
else:
|
else:
|
||||||
logger.info("写入PLC成功,写入的内容:%s", str(results))
|
logger.debug("写入PLC成功,写入的内容:%s", str(results))
|
||||||
return 1, "", results
|
return 1, "", results
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
|
@ -92,7 +96,6 @@ class PLC_Tool:
|
||||||
logger.error("写入PLC异常,计划写入的内容:%s 。 异常反馈:%s", str(tags), traceback.format_exc())
|
logger.error("写入PLC异常,计划写入的内容:%s 。 异常反馈:%s", str(tags), traceback.format_exc())
|
||||||
return 0, str(io_error), None
|
return 0, str(io_error), None
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.batch_write_tag(tags)
|
return self.batch_write_tag(tags)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
|
@ -118,27 +121,27 @@ class PLC_Tool:
|
||||||
# return False, "请输入标签'%s'的新值value:str" % tag
|
# return False, "请输入标签'%s'的新值value:str" % tag
|
||||||
|
|
||||||
# print("需要写入的数据 %s:%s" % (tag, str(value)))
|
# print("需要写入的数据 %s:%s" % (tag, str(value)))
|
||||||
logger.info("准备写入PLC的数据:%s:%s", tag, str(value))
|
logger.debug("准备写入PLC的数据:%s:%s", tag, str(value))
|
||||||
ret = self.comm.Write(tag, value)
|
ret = self.comm.Write(tag, value)
|
||||||
|
|
||||||
if ret.Status != "Success":
|
if ret.Status == "Success":
|
||||||
logger.error("存在写入失败的标签, 计划写入的信息:%s:%s", tag, str(value))
|
logger.debug("写入PLC成功,写入的数据:%s:%s", tag, str(value))
|
||||||
return False, "存在写入失败的标签"
|
|
||||||
else:
|
|
||||||
logger.info("写入PLC成功,写入的数据:%s:%s", tag, str(value))
|
|
||||||
return True, ""
|
return True, ""
|
||||||
|
else:
|
||||||
|
logger.error("存在写入失败的标签, 请重试。计划写入的信息:%s:%s", tag, str(value))
|
||||||
|
return False, "存在写入失败的标签,请重试。"
|
||||||
|
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
print(traceback.format_exc())
|
# print(traceback.format_exc())
|
||||||
logger.error("写入PLC异常,计划写入的内容:%s:%s 。 异常反馈:%s", tag, str(value), traceback.format_exc())
|
logger.error("写入PLC异常,请重试。计划写入的内容:%s:%s 。 异常反馈:%s", tag, str(value), traceback.format_exc())
|
||||||
return False, str(io_error)
|
return False, "写入PLC异常,请重试。计划写入的内容:%s:%s 。 异常反馈:%s" % (tag, str(value), traceback.format_exc())
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.write_tag(tag, value)
|
return self.write_tag(tag, value)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
# print(traceback.format_exc())
|
||||||
logger.error("写入PLC异常,计划写入的内容:%s:%s 。 异常反馈:%s", tag, str(value), traceback.format_exc())
|
logger.error("写入PLC异常,请重试。计划写入的内容:%s:%s 。 异常反馈:%s", tag, str(value), traceback.format_exc())
|
||||||
return False, str(e)
|
return False, "写入PLC异常,请重试。计划写入的内容:%s:%s 。 异常反馈:%s" % (tag, str(value), traceback.format_exc())
|
||||||
|
|
||||||
def write_array(self, tag: str, array: list):
|
def write_array(self, tag: str, array: list):
|
||||||
"""
|
"""
|
||||||
|
@ -164,24 +167,26 @@ class PLC_Tool:
|
||||||
# "value": ret.Value,
|
# "value": ret.Value,
|
||||||
# "status": ret.Status
|
# "status": ret.Status
|
||||||
# }]
|
# }]
|
||||||
if ret.Status != "Success":
|
if ret.Status == "Success":
|
||||||
|
pass
|
||||||
|
else:
|
||||||
logger.error("数组信息写入失败,计划写入内容:%s:%s", tag, str(array))
|
logger.error("数组信息写入失败,计划写入内容:%s:%s", tag, str(array))
|
||||||
return False, "数组信息写入失败"
|
return False, "数组信息写入失败,计划写入内容:%s:%s" % (tag, str(array))
|
||||||
logger.info("数组信息写入成功,写入内容:%s:%s", tag, str(array))
|
logger.debug("数组信息写入成功,写入内容:%s:%s", tag, str(array))
|
||||||
return True, ""
|
return True, ""
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
print(traceback.format_exc())
|
# print(traceback.format_exc())
|
||||||
logger.error("数组信息写入失败,计划写入内容:%s:%s, 反馈的异常信息:%s", tag, str(array), traceback.format_exc())
|
logger.error("数组信息写入失败,请重试。计划写入内容:%s:%s, 反馈的异常信息:%s", tag, str(array), traceback.format_exc())
|
||||||
return False, str(io_error)
|
return False, "数组信息写入失败,请重试。计划写入内容:%s:%s, 反馈的异常信息:%s" % (tag, str(array), traceback.format_exc())
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.write_array(tag, array)
|
return self.write_array(tag, array)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
# print(traceback.format_exc())
|
||||||
logger.error("数组信息写入失败,计划写入内容:%s:%s, 反馈的异常信息:%s", tag, str(array),
|
logger.error("数组信息写入失败,请重试。计划写入内容:%s:%s, 反馈的异常信息:%s", tag, str(array),
|
||||||
|
traceback.format_exc())
|
||||||
|
return False, "数组信息写入失败,请重试。计划写入内容:%s:%s, 反馈的异常信息:%s" % (tag, str(array),
|
||||||
traceback.format_exc())
|
traceback.format_exc())
|
||||||
return False, str(e)
|
|
||||||
|
|
||||||
def get_tags(self, tags: [str, list]):
|
def get_tags(self, tags: [str, list]):
|
||||||
"""
|
"""
|
||||||
|
@ -199,7 +204,7 @@ class PLC_Tool:
|
||||||
if len(tags) == 0:
|
if len(tags) == 0:
|
||||||
return False, "请输入标签tags:list", None
|
return False, "请输入标签tags:list", None
|
||||||
|
|
||||||
logger.info("读取PLC的点位信息,所读点位:%s", str(tags))
|
logger.debug("读取PLC的点位信息,所读点位:%s", str(tags))
|
||||||
rets = self.comm.Read(tags)
|
rets = self.comm.Read(tags)
|
||||||
for ret in rets:
|
for ret in rets:
|
||||||
results.append(
|
results.append(
|
||||||
|
@ -210,7 +215,7 @@ class PLC_Tool:
|
||||||
if ret.Status != "Success":
|
if ret.Status != "Success":
|
||||||
logger.error("读取PLC的点位失败,反馈结果:%s", str(results))
|
logger.error("读取PLC的点位失败,反馈结果:%s", str(results))
|
||||||
return False, "读取PLC点位失败", results
|
return False, "读取PLC点位失败", results
|
||||||
logger.info("已读取到PLC的点位信息,读取结果:%s", str(results))
|
logger.debug("已读取到PLC的点位信息,读取结果:%s", str(results))
|
||||||
return True, "", results
|
return True, "", results
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
|
@ -219,7 +224,6 @@ class PLC_Tool:
|
||||||
return False, str(io_error), None
|
return False, str(io_error), None
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
self.connect()
|
|
||||||
return self.get_tags(tags)
|
return self.get_tags(tags)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
|
@ -244,7 +248,7 @@ class PLC_Tool:
|
||||||
if count <= 0:
|
if count <= 0:
|
||||||
return False, "取数个数应大于0", None
|
return False, "取数个数应大于0", None
|
||||||
|
|
||||||
logger.info("读取PLC的数组信息,所读点位:%s[%d]", str(tag), count)
|
logger.debug("读取PLC的数组信息,所读点位:%s[%d]", str(tag), count)
|
||||||
ret = self.comm.Read(tag, count)
|
ret = self.comm.Read(tag, count)
|
||||||
results = {"tagName": ret.TagName,
|
results = {"tagName": ret.TagName,
|
||||||
"value": ret.Value,
|
"value": ret.Value,
|
||||||
|
@ -253,7 +257,7 @@ class PLC_Tool:
|
||||||
if ret.Status != "Success":
|
if ret.Status != "Success":
|
||||||
logger.error("读取PLC的数组失败,所读点位:%s[%d], 反馈结果:%s", tag, count, str(results))
|
logger.error("读取PLC的数组失败,所读点位:%s[%d], 反馈结果:%s", tag, count, str(results))
|
||||||
return False, "读取PLC的数组失败", results
|
return False, "读取PLC的数组失败", results
|
||||||
logger.info("已读取PLC的数组信息,读取结果:%s", str(results))
|
logger.debug("已读取PLC的数组信息,读取结果:%s", str(results))
|
||||||
return True, "", results
|
return True, "", results
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
|
@ -261,7 +265,6 @@ class PLC_Tool:
|
||||||
logger.error("读取PLC的数组失败,所读点位:%s[%d], 反馈错误信息:%s", tag, count, traceback.format_exc())
|
logger.error("读取PLC的数组失败,所读点位:%s[%d], 反馈错误信息:%s", tag, count, traceback.format_exc())
|
||||||
return False, str(io_error), None
|
return False, str(io_error), None
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.get_array(tag, count)
|
return self.get_array(tag, count)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
|
@ -276,11 +279,11 @@ class PLC_Tool:
|
||||||
connect_count: int = 0
|
connect_count: int = 0
|
||||||
results = []
|
results = []
|
||||||
try:
|
try:
|
||||||
logger.info("获取PLC所有标签")
|
logger.debug("获取PLC所有标签")
|
||||||
tags = self.comm.GetTagList()
|
tags = self.comm.GetTagList()
|
||||||
for t in tags.Value:
|
for t in tags.Value:
|
||||||
results.append({t.TagName: t.DataType})
|
results.append({t.TagName: t.DataType})
|
||||||
logger.info("已获取到PLC所有标签, 标签列表:%s", str(results))
|
logger.debug("已获取到PLC所有标签, 标签列表:%s", str(results))
|
||||||
return results
|
return results
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
|
@ -288,7 +291,6 @@ class PLC_Tool:
|
||||||
logger.error("获取PLC所有标签失败,反馈错误信息:%s", traceback.format_exc())
|
logger.error("获取PLC所有标签失败,反馈错误信息:%s", traceback.format_exc())
|
||||||
return None
|
return None
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.get_tag_list()
|
return self.get_tag_list()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
|
@ -303,9 +305,9 @@ class PLC_Tool:
|
||||||
"""
|
"""
|
||||||
connect_count: int = 0
|
connect_count: int = 0
|
||||||
try:
|
try:
|
||||||
logger.info("开始获取PLC时间")
|
# logger.debug("开始获取PLC时间")
|
||||||
time = self.comm.GetPLCTime(raw)
|
time = self.comm.GetPLCTime(raw)
|
||||||
logger.info("获取PLC时间成功:%s", str(time))
|
# logger.debug("获取PLC时间成功:%s", str(time))
|
||||||
return time
|
return time
|
||||||
except IOError as io_error:
|
except IOError as io_error:
|
||||||
if connect_count > 0:
|
if connect_count > 0:
|
||||||
|
@ -313,7 +315,6 @@ class PLC_Tool:
|
||||||
logger.error("获取PLC时间失败,反馈错误信息:%s", traceback.format_exc())
|
logger.error("获取PLC时间失败,反馈错误信息:%s", traceback.format_exc())
|
||||||
return None
|
return None
|
||||||
connect_count += 1
|
connect_count += 1
|
||||||
self.connect()
|
|
||||||
return self.get_plc_time()
|
return self.get_plc_time()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(traceback.format_exc())
|
print(traceback.format_exc())
|
||||||
|
|
|
@ -21,7 +21,7 @@ class Log(object):
|
||||||
self.fileHandler = RotatingFileHandler(filename="%s/log.log" % self.logPath,
|
self.fileHandler = RotatingFileHandler(filename="%s/log.log" % self.logPath,
|
||||||
mode="a",
|
mode="a",
|
||||||
maxBytes=10485760,
|
maxBytes=10485760,
|
||||||
backupCount=10,
|
backupCount=20,
|
||||||
encoding="utf-8")
|
encoding="utf-8")
|
||||||
|
|
||||||
# 设置日志级别
|
# 设置日志级别
|
||||||
|
|
|
@ -36,3 +36,6 @@ logger.info("日志地址:%s 打印日志级别:%s 存储日志级别:%s",
|
||||||
logger.info("PLC地址:%s 插槽:%d 超时:%d秒 最小读取间隔:%d毫秒", config.ip_address, config.slot, config.timeout,
|
logger.info("PLC地址:%s 插槽:%d 超时:%d秒 最小读取间隔:%d毫秒", config.ip_address, config.slot, config.timeout,
|
||||||
config.interval_plc)
|
config.interval_plc)
|
||||||
logger.debug("车厢最大数:%d", config.carriage_num_max)
|
logger.debug("车厢最大数:%d", config.carriage_num_max)
|
||||||
|
|
||||||
|
g_read_plc = None
|
||||||
|
g_write_plc = None
|
||||||
|
|
Loading…
Reference in New Issue