- {{item.name}}
在WinCC中如何使用VBS读取报警记录数据到EXCEL
- 0
- 1531
- 7733
1概述
介绍如何在WinCC项目中使用VBS脚本读取报警记录归档数据,并把获取的数据保存成新的Excel文件。
2软件环境
Windows XP SP3中文版、WinCC7.0 SP2 ASIA、Microsoft office Excel 2007
3访问原理
WinCC报警记录数据是以压缩的形式存储在数据库中,需要通过 WinCC连通性软件包提供的OLE-DB接口才能够解压并读取这些数据。关于WinCC连通性软件包的详细信息请参考连接:37436159
当使用 OLE-DB方式访问数据库时关键需要注意连接字符串的写法和查询语句的格式。连接字符串格式为“Provider= WinCCOLEDBProvider.1; Catalog= ***; Data Source= ***;”,其中:Catalog为WinCC运行数据库的名称, 当修改项目名称或在其它计算机上打开原项目时, Catalog会发生变化。建议使用WinCC内部变量 “@DatasourceNameRT” 获得当前项目的Catalog。Data Source 为服务器名称,格式为“<计算机名称>\WinCC”。
3.1 查询语句格式
查询语句的格式要求如下:
AlARMVIEW:SELECT * FROM <ViewName> [ WHERE<Condition>……optional ]
其中参数信息如下所示:
ViewName:数据库表名。必须用需要的语言指定该表。
比如:中文字符表名为:ALGVIEWCHT,英文字符表明为:ALGVIEWENU等。
Condition:为过滤标准。
详细说明请参见下表:
表1查询参数表
3.2查询结果
查询结果作为记录集返回。可以根据需要有选择的返回特定的数据集。例如:oRs.Fields(0).Value 返回的是消息的编号;oRs.Fields(2).Value 返回的是消息的时间戳;oRs.Fields(37).Value返回的是消息文本的内容。记录集的结构如下表所示:
表2记录集结构
表3记录集结构 (续表)
注意:WinCC的归档数据是使用UTC(协调世界时)时间保存的。本例中所采用的时间均为UTC时间,如果需要实现在本地时间和UTC时间之间的转换,请参考下列连接:
如何计算本地时间和 UTC 时间的时间差,如何转换 UTC 时间成 SQL 语句格式?
如何将本地计算机时间的时间戳(日期时间)转换成协调世界时 (UTC)?
4组态介绍
4.1准备工作
1)创建变量
其中AlmTagA、AlmTagB和AlmTagC用于组态报警,MySqlStr用于动态化查询条件。如下图所示:
图1变量
2)组态报警
在报警记录中组态如下报警:
图2报警信息
图3单个消息组态界面
3)创建Excel模板
在特定的路径下预先创建一个Excel文件作为模板,这样可以很好的控制输出格式。本例中在D:\WinCCWriteExcel下创建一个名称为abc.xlsx的Excel文件。如下图所示:
图4EXCEL模板
4.2组态查询界面
画面上新建五个按钮,上面的四个按钮分别用于设置不同的查询条件。按钮下方的静态文本用于显示查询条件。最下方的按钮用于执行查询报警记录的VBS脚本。其中查询条件的设定是通过按钮的直接连接方式实现。
图5 查询界面
在按钮属性对话框的鼠标动作中选择直接连接打开如下界面,配置查询条件。其中来源部分为查询字符串,目标部分为存储查询条件的变量。
图6按钮直接连接配置
4.3详细脚本介绍
1)打开Excel模板以后台方式打开之前创建好的Excel模板。其中sheetname作为变量可以定义Excel中Sheet的名字。需要注意模板文件的存储路径。Set objExcelApp = CreateObject("Excel.Application")objExcelApp.Visible = FalseobjExcelApp.Workbooks.Open "D:\WinCCWriteExcel\abc.xlsx"objExcelApp.Worksheets(sheetname).Activate2)准备查询条件主要是确定和格式化Catalog和查询条件。关键脚本如下:'准备查询条件 CatalogSet tagDSNName = HMIRuntime.Tags("@DatasourceNameRT")tagDSNName.Read‘拼接查询条件MySqlStr.ReadsSql = "ALARMVIEW:Select * FROM AlgViewCHT "&MySqlStr.Value其中MySqlStr为定义的内部字符串类型的变量,当点击查询条件中的按钮时 ,就会把相应的查询条件字符串传给该变量(需要根据项目的实际情况调整查询条件)。本例中的四条查询条件的完整语句如下图所示:
图7查询条件
3)完整的代码'变量定义和初始化Dim sPro,sDsn,sSer,sCon,conn,sSql,oRs,oComDim tagDSNNameDim m,iDim objExcelApp,objExcelBook,objExcelSheet,sheetnameDim MySqlStrSet MySqlStr = HMIRuntime.Tags("MySqlStr")item.Enabled = False'On Error Resume Nextsheetname="Sheet1"'打开Excel模板Set objExcelApp = CreateObject("Excel.Application")objExcelApp.Visible = FalseobjExcelApp.Workbooks.Open "D:\WinCCWriteExcel\abc.xlsx"objExcelApp.Worksheets(sheetname).Activate'准备查询条件 CatalogSet tagDSNName = HMIRuntime.Tags("@DatasourceNameRT")tagDSNName.Read'创建数据库联接sPro = "Provider=WinCCOLEDBProvider.1;"sDsn = "Catalog=" &tagDSNName.Value& ";"sSer = "Data Source=.\WinCC"sCon = sPro + sDsn + sSerSet conn = CreateObject("ADODB.Connection")conn.ConnectionString = sConconn.CursorLocation = 3conn.Open'定义查询的命令文本 SQLMySqlStr.ReadsSql = "ALARMVIEW:Select * FROM AlgViewCHT "&MySqlStr.ValueHMIRuntime.Trace "Sql is: " & sSql & vbCrLfSet oRs = CreateObject("ADODB.Recordset")Set oCom = CreateObject("ADODB.Command")oCom.CommandType = 1Set oCom.ActiveConnection = connoCom.CommandText = sSql'填充数据到Excel中Set oRs = oCom.Executem = oRs.RecordCountIf (m > 0) ThenoRs.MoveFirsti=3Do While Not oRs.EOF '是否到记录末尾,循环填写表格objExcelApp.Worksheets(sheetname).cells(i,1).value= CStr(oRs.Fields(0).Value)objExcelApp.Worksheets(sheetname).cells(i,2).value= CStr(oRs.Fields(1).Value)objExcelApp.Worksheets(sheetname).cells(i,3).value= CStr(oRs.Fields(2).Value)objExcelApp.Worksheets(sheetname).cells(i,4).value= CStr(oRs.Fields(37).Value)oRs.MoveNexti=i+1LoopoRs.CloseElseMsgBox "没有所需数据……"item.Enabled = TrueSet oRs = Nothingconn.CloseSet conn = NothingobjExcelApp.Workbooks.CloseobjExcelApp.QuitSet objExcelApp= NothingExit SubEnd If'释放资源Set oRs = Nothingconn.CloseSet conn = Nothing'生成新的文件,关闭ExcelDim patch,filenamefilename=CStr(Year(Now))&CStr(Month(Now))&CStr(Day(Now))&CStr(Hour(Now))+CStr(Minute(Now))&CStr(Second(Now))patch= "d:\"&filename&"demo.xlsx"objExcelApp.ActiveWorkbook.SaveAs patchobjExcelApp.Workbooks.CloseobjExcelApp.QuitSet objExcelApp= NothingMsgBox "成功生成数据文件!"item.Enabled = True
5结果和建议
下图为程序执行的结果。仅供参考:
图8输出结果
建议:为了改善本地访问期间的性能,请输入“<计算机名称>\WinCC”作为数据源,而不是“.\WinCC”。为了提高系统的执行效率,建议仅读取少量的数据。为了避免可能造成的数据损失,建议在执行操作之前先退出Excel应用程序。
声明:
本文所述的方法为WinCC的高级用法,提供的代码程序仅供用户参考,西门子公司不提供任何调试和热线支持。敬请谅解!
程序实例:VBSReadAlarm.zip ( 8720 KB )
关键词
WinCC、Excel、VBS、脚本、连通性软件包
剩余80%未阅读,请登录后下载/查看文档
- 评论
-
分享
扫码分享
- 收藏 收藏
- 点赞 点赞
- 纠错 纠错
- 在 WinCC 运行系统中如何连接或断开已经导出的报警记录或变量记录的归档片段?
- 在 STEP 7 (TIA Portal) 中如何从一个数据块复制存储区和结构体数据到另一个数据块?
- 在 WinCC flexible 中如何使用 VBS 脚本实现等待功能(延时)?
- 如何装载项目数据到存储卡上?以便在没有 TIA Portal 的情况下,使用存储卡向 S7-1200 /S7-1500CPU 传输程序
- 如何更改 WinCC 报警记录的采集周期?
- 如何使用Excel通过OPC访问WinCC的实时数据
- 为什么 (WinCC V7 和 WinCC Professional) 在启动项中勾选 "报警记录运行系统" 或 "变量记录运行系统"时激活会卡住?
- MM4 变频器故障报警记录如何清除
- 在CFC图中如何使用全局操作符将不同的数据类型和参数连接在一起?
- S7-300中如何使用通信功能块FB12 "BSEND" 和 FB13 "BRCV"进行数据交换?
{{item.nickName}}