客户端C#读取opc数据
来源:互联网 发布:spyder tensorflow 编辑:程序博客网 时间:2024/05/29 12:20
关于OPC这个东西,网上文章很多。作为一个需要取数的程序员来说,需要知道的就是客户端的一些设置,至于服务器端,想知道的自己去百度撸吧。
客户端读取数据,网上很多,但是在刚开始的时候总会遇到各种问题,在这里写点,权且自己当个记录吧。
首先是引用一个dll, 名称 OPCDAAuto.dll 这个哪里下载,百度一下,很多的
OPCDAAuto.dll 需要注册 regsvr32 /s OPCDAAuto.dll
using OPCAutomation;
//OPC 变量
#region 私有变量 OPCServer KepServer; OPCGroups KepGroups; OPCGroup KepGroup; OPCItems KepItems; #endregion
开始抓取数据
/// <summary> /// OPC服务器 /// 开始抓取OPC数据 /// </summary> public void Start() { try { KepServer.Connect("10.3.4.109","Matrikon.OPC.Simulation.1"); //判断连接状态 if (KepServer.ServerState == (int)OPCServerState.OPCRunning) { SendMsg("已连接到-" + KepServer.ServerName); } else { SendMsg("状态:" + KepServer.ServerState.ToString()); return; } KepGroups = KepServer.OPCGroups; Task.Factory.StartNew(CreateGroup); //this.GatherData = true; } catch(Exception e) { throw e; } }
公共函数
private void SendMsg(string m) { //LogHelper.WriteLog(m); }
/// <summary> /// 创建组 /// </summary> private void CreateGroup() { try { KepGroups = KepServer.OPCGroups; KepGroup = KepGroups.Add("OpcGroup"); SetGroupProperty(); KepGroup.DataChange += new DIOPCGroupEvent_DataChangeEventHandler(KepGroup_DataChange); //KepGroup.AsyncWriteComplete += new DIOPCGroupEvent_AsyncWriteCompleteEventHandler(KepGroup_AsyncWriteComplete); KepItems = KepGroup.OPCItems; AddOpcItem(); } catch (Exception err) { SendMsg("枚举本地OPC创建组出现错误:" + err.Message); } }设置采集属性
/// <summary> /// 设置组属性 /// </summary> private void SetGroupProperty() { KepServer.OPCGroups.DefaultGroupIsActive = true; KepServer.OPCGroups.DefaultGroupDeadband = 0; KepGroup.UpdateRate = 3000; KepGroup.IsActive = true; KepGroup.IsSubscribed = true; }
把需要采集数据的点加进去
private void AddOpcItem() { KepItems.AddItem("a1.22.1", 1); KepItems.AddItem("a2.22.2", 2); KepItems.AddItem("a3.22.3", 3); }
点数据发送变化的事件
/// <summary> /// 每当项数据有变化时执行的事件 /// </summary> /// <param name="TransactionID">处理ID</param> /// <param name="NumItems">项个数</param> /// <param name="ClientHandles">项客户端句柄</param> /// <param name="ItemValues">TAG值</param> /// <param name="Qualities">品质</param> /// <param name="TimeStamps">时间戳</param> private void KepGroup_DataChange(int TransactionID, int NumItems, ref Array ClientHandles, ref Array ItemValues, ref Array Qualities, ref Array TimeStamps) { try { for (int i = 1; i <= NumItems; i++) { string temp = string.Concat(ClientHandles.GetValue(i),"-",ItemValues.GetValue(i), "-",Qualities.GetValue(i), "-",TimeStamps.GetValue(i)); SendMsg(temp); } } catch (Exception e) { SendMsg("KepGroup_DataChange" + e.Message); } }
基本上就这样了,整理一下,理解一下,入门没问题,OPC数据的读取还是比较简单的,利用上面的代码,写个简单的程序,把数据读出来没有问题的。
其实如果不喜欢或者不会写程序,也可以用 KEPServerEx软件,配置一下就能搞定。这个玩意是外国人写,运行稳定,并且支持sql,oracle等多种数据库。虽然是要钱的,但是这个难不倒我们中国人,有破解版。
这个代码运行有个前提,那就是客户端是服务器端必须是通的。这个通是用标准的OPC客户端能连上,不是网络上能ping通。
什么是标准的OPC客户端客户端。OPC Client.exe 网上也有下载。
如果标准OPC客户端也连接不上,那就数说明需要客户端需要配置dcom,具体怎么配置,百度一下,本文主要是负责写代码
阅读全文
1 0
- 客户端C#读取opc数据
- OPC客户端读取Server数据
- C# OPC客户端
- OPC客户端抓数据
- C# OPC客户端远程连接RSLinx OPC服务器
- C#写的OPC客户端示例源代码
- JAVA使用JeasyOPC读取OPC 服务器数据
- 关于C#开发OPC客户端无法连接远程的解决办法
- C# 的OPC客户端 (Advosol OPCDA.NET组件)
- 对组态王OPC服务器值的读取c#版本
- KEPServerEx OPC 读取西门子 PLC S7200 SMART的数据
- OPC客户端报错
- OPC客户端学习
- 如何在C#中实现OPC数据访问
- java读取opc服务器
- OPC Client 聊一下关于opc客户端
- 标准OPC Client(OPC客户端)使用说明
- c#读取客户端控件内容
- EBS接口问题查看@2017-6-27
- EasyUI学习总结(六)——EasyUI布局
- Spring Security(03)——核心类简介
- 松下FP系列PLC以太网modbusTCP通讯
- websocket入门(2)——使用socket.io实现网络对战版五子棋
- 客户端C#读取opc数据
- android开发——使用java读取.shp(shapefile)矢量文件
- android应用中去掉标题栏的方法
- Spring Security(04)——认证简介
- Android 应用发布流程
- 如何禁止TextBox的记忆功能
- MUI开发时genymotion模拟器连不上Hbuilder解决办法
- ajax请求与UI进程阻塞
- JavaScript 类型判定