这篇文章的https://blog.csdn.net/liwen9016/article/details/89640491描述了OPC如何开发OPC DA客户端,并使用异步的方式读取数据,但是这篇文章的代码不完整。
经过我的自己思考,将它补充完整。
愣着干嘛,赶紧点赞
先上成功的截图:
完整代码如下:
import time, Common
from typing import List
import win32timezone, datetime
import win32com.client, pythoncom
from win32com.client import gencache
import win32timezone
from win32com.client import Dispatch
from win32com.client import DispatchWithEvents
class groupEvent(object):
def OnDataChange(self, TransactionID, NumItems, ClientHandles, ItemValues, Qualities, TimeStamps):
i = 0
print("callback")
while (i < NumItems):
handle = ClientHandles[i]
value = ItemValues[i]
quality = Qualities[i]
time = TimeStamps[i]
print("item:%s , value:%s , quality:%s , time:%s ", item_name_map[handle], value, quality, time)
i = i + 1
OPC_DA_DLL = gencache.EnsureModule('{28E68F91-8D75-11D1-8DC3-3C302A000000}', 0, 1, 0)
opcServer = OPC_DA_DLL.OPCServer()
opcServer.Connect('PCAuto.OPCServer', "192.168.1.119")
item_name_map = {}
# 拿到组实例
groups = opcServer.OPCGroups
groups.DefaultGroupIsActive = True
groups.DefaultGroupDeadband = 0
groups.DefaultGroupUpdateRate = 200
# 添加组,并订阅回调事件,因为a1.pv这个点直属root,所以add函数里面是空
group = DispatchWithEvents(groups.Add(''), groupEvent)
group.IsActive = True
group.IsSubscribed = True
group.UpdateRate = 100
items = group.OPCItems
# 添加需要操作的条目
item1 = "a1.pv"
item = items.AddItem(item1, 1)
item.IsActive = True
item_name_map[1] = item
#这里是等待回调事件的发生
pythoncom.PumpMessages()
while True:
time.sleep(1)