news 2026/4/24 21:51:33

wincc与Excel数据交互,全脚本实现,根据条件自动查询数据到wincc系统,适合winc...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
wincc与Excel数据交互,全脚本实现,根据条件自动查询数据到wincc系统,适合winc...

wincc与Excel数据交互,全脚本实现,根据条件自动查询数据到wincc系统,适合wincc实际运行时,需要根据实际需求条件从表格中查询数据,使用数据集方式,不用每次都加载Excel,提高数据查询的速度

最近在调试WinCC项目时遇到个需求:需要根据设备实时状态从两千多条Excel记录中快速抓取参数。试过常规的VBA交互方案,发现每次查询都要重新加载Excel,速度慢得能赶上老牛拉破车。折腾两天搞出了个全脚本的优化方案,实测查询速度从8秒缩短到0.3秒,这里把实现思路分享给大家。

先说痛点,传统方案是这样的:

Function QueryData(condition) Set excel = CreateObject("Excel.Application") Set workbook = excel.Workbooks.Open("D:\data.xlsx") '...循环查找数据...' workbook.Close excel.Quit End Function

每查一次数据都要开闭Excel对象,相当于每次都要把整本字典从头翻到尾。数据量小还行,遇到几千条记录直接卡成PPT。

改进方案用ADO+内存驻留,先把Excel数据吃到内存里:

Dim globalData '声明全局变量存数据 Sub InitData() connStr = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\data.xlsx;Extended Properties='Excel 12.0;HDR=Yes;IMEX=1'" Set conn = CreateObject("ADODB.Connection") conn.Open connStr Set rs = CreateObject("ADODB.Recordset") rs.Open "SELECT * FROM [Sheet1$]", conn globalData = rs.GetRows() '关键操作:二维数组存储数据' rs.Close conn.Close End Sub

这里GetRows方法直接把整个Excel表转成二维数组,实测加载2000行x20列数据约1.2秒。建议在工程启动时调用InitData,或者做个数据刷新按钮。

wincc与Excel数据交互,全脚本实现,根据条件自动查询数据到wincc系统,适合wincc实际运行时,需要根据实际需求条件从表格中查询数据,使用数据集方式,不用每次都加载Excel,提高数据查询的速度

查询函数改成内存操作:

Function FastQuery(deviceID) If Not IsArray(globalData) Then InitData '防呆设计 For row = 0 To UBound(globalData, 2) If globalData(0, row) = deviceID Then '假设设备ID在第一列 FastQuery = globalData(3, row) '返回第四列参数 Exit Function End If Next End Function

这里有个坑要注意:GetRows返回的数组是[列,行]结构,和常规认知相反。用UBound(globalData,2)获取总行数,取数时记得先列后行。

更高级的玩法可以用字典建立哈希索引,适合精确匹配:

Dim dict Sub BuildIndex() Set dict = CreateObject("Scripting.Dictionary") For row = 0 To UBound(globalData, 2) key = globalData(0, row) & "|" & globalData(1, row) '组合键 dict.Add key, row Next End Sub Function SuperQuery(line, device) indexKey = line & "|" & device If dict.Exists(indexKey) Then SuperQuery = globalData(5, dict(indexKey)) '取第六列参数 End If End Function

这种预先生成索引的方式,能把查询时间压缩到毫秒级。实测5000条数据下,传统方案8.7秒,数组遍历0.3秒,字典查询0.002秒,速度差异堪比高铁和共享单车。

最后在WinCC里挂接个查询按钮:

Sub Button_Click() currentID = SmartTags("DeviceID") '从PLC读取当前设备ID result = FastQuery(currentID) SmartTags("TargetValue") = result End Sub

几个优化建议:

  1. Excel文件用另存为"Excel 97-2003 工作簿"格式,兼容性更好
  2. 数据变化后记得重新InitData和BuildIndex
  3. 字段较多时建议用常量定义列号,比如Const COL_TEMP = 3
  4. 错误处理要加到位,特别是文件被占用时的异常捕获

这种方案在需要频繁调参的生产线场景特别好用,比如不同型号产品切换时,省去了人工查表的麻烦。曾有个项目用这种方法实现200+设备参数自动装载,比原计划的数据库方案节省了80%实施时间。

最后提醒:别在脚本里用Select *,明确指定需要的列能减少内存占用。就像搬家别把整个房子带走,只带必要的家具就好。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 16:26:05

Qwen3-0.6B情感分析实战:搭建舆情监控系统的可行性验证

Qwen3-0.6B情感分析实战:搭建舆情监控系统的可行性验证 1. 引言 1.1 舆情监控的技术背景与挑战 在社交媒体高度发达的今天,企业、政府机构乃至公众人物对网络舆情的敏感度日益提升。及时掌握用户评论、新闻报道、论坛讨论中的情绪倾向,已成…

作者头像 李华
网站建设 2026/4/16 8:45:25

Unity游戏自动翻译终极解决方案:XUnity.AutoTranslator深度解析

Unity游戏自动翻译终极解决方案:XUnity.AutoTranslator深度解析 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为游戏多语言本地化而烦恼吗?XUnity.AutoTranslator作为业界领…

作者头像 李华
网站建设 2026/4/23 11:10:38

实战Java微信小程序商城:一套代码玩转多端SaaS架构

Java微信小程序商城源码,Java微信开发框架源码,saas模式,前后端分离小程序商城源码 需要看演示的,咨询客服。 使用高性能的Java语言开发,采用目前流行的微服务前后端分离框架,拥有完整的后台,小…

作者头像 李华
网站建设 2026/4/16 21:23:04

基于Matlab的车牌识别系统:模板匹配与神经网络的探索

基于matlab的车牌识别系统,可以用模板匹配设计也可以用网络神经算法,全网最全资料在智能交通日益发展的今天,车牌识别系统成为了一个热门的研究与应用领域。Matlab以其强大的矩阵运算能力和丰富的工具箱,为我们实现车牌识别系统提…

作者头像 李华
网站建设 2026/4/17 22:00:11

Wan2.2-T2V-A5B详解:轻量化设计背后的模型蒸馏技术解析

Wan2.2-T2V-A5B详解:轻量化设计背后的模型蒸馏技术解析 1. 技术背景与问题提出 近年来,文本到视频(Text-to-Video, T2V)生成技术在内容创作、广告设计和影视预演等领域展现出巨大潜力。然而,主流T2V模型通常参数量庞…

作者头像 李华
网站建设 2026/4/22 20:22:12

S7-200自由口协议实现英威腾GD200变频器控制与数据读取

S7-200自由口协议,带详细注释,本例以自由口通讯控制英威腾GD200变频器启停及其读取变频反馈数据在自动化控制领域,实现PLC与变频器的有效通讯至关重要。今天咱就来讲讲如何利用S7-200的自由口协议来控制英威腾GD200变频器的启停,并…

作者头像 李华