通过VBS脚本在ListView控件中显示WinCC的变量记录

时间:2023-03-18来源:佚名
在实际应用中,客户对于WinCC变量记录的显示需求各式各样,比如在Excel或者Word中显示变量记录,以特定的表格显示历史数据等等。当WinCC集成的在线表格控件不能满足客户需要时,就需要通过自定义的方式来显示变量归档。主要分为两部分:
(1)从WinCC中读取归档数据
(2)将归档数据以特定的格式显示出来
本文档介绍从WinCC读取归档数据的通用方法,并以ListView为例,介绍如何显示归档数据。对于其它控件,客户也可以参考本文档的脚本和编程思路。

1.测试环境
本文档基于WinCC V7.0 ASIA,并通过MS Windows Common Controls 6.0 ListView 控件来显示读取的归档数据。需要的授权如下:

授权名称 个数 备注
WinCC RC V7.0 1
WinCC连通性软件包V7.0 1 订货号为:6AV6371-1DR07-0AX0,授权通过WinCC OLE DB访问过程值归档。

表 01

2.实现方式总体思路介绍
本文档通过调用WinCC OLE DB数据库接口驱动(需要WinCC连通性软件包的授权)来访问WinCC的变量归档,并在微软的ListView控件中显示归档数据。程序结构如下所示:

通过VBS脚本在ListView控件中显示WinCC的变量记录
图1

其中,自定义函数的说明如下表所示:

函数名称 功能
WinCCDataSourceAccess(connObj, pSQL) 建立到数据库的连接。参数connObj为连接对象(ADODB.Connection),参数pSQL为要执行的SQL查询语句
WinCCDataSourceClose(pRecordset, connObj) 断开与数据库的连接,释放资源。参数pRecordset为ADODO.RecordSet对象,参数connObj为连接对象(ADODB.Connection)
AddListViewHeaderColumn(pRecordset, pListView) 添加ListView的列名。参数pRecordset为ADODO.RecordSet对象,参数pListView为ListView对象
FillListView (pRecordset, pListView) 参数pRecordset为ADODO.RecordSet对象,参数pListView为ListView对象。

表 02

具体代码见附件。

3.具体实现方法和代码

3.1 创建到归档数据库的连接

由于WinCC的变量归档为压缩数据,所以必须通过WinCC OLE DB来读取归档数据。对于已经安装WinCC的计算机,不需要安装WinCC连通性软件包。对于未安装WinCC的客户端,必须安装WinCC连通性软件包。该软件包含在WinCC V7.0的安装光盘中。
数据库连接的脚本如下所示:
'定义数据库连接变量
Dim conn

Set conn = CreateObject("ADODB.Connection")

'定义数据库查询脚本(可以根据需要自定义修改)
Dim sSQL

sSQL="Tag:R,'ProcessValueArchiveTag1','0000-00-00 00:01:00.000','0000-00-00 00:00:00.000'"

'通过调用自定义的数据库连接函数,建立与数据库的连接
Dim oRs

Set oRs= WinCCDataSourceAccess(conn,sSQL)

其中,自定义的数据库连接函数WinCCDataSourceAccess(connObj,pSQL),参数connObj为连接对象(ADODB.Connection),参数pSQL为要执行的SQL查询语句,具体代码如下所示:
Function WinCCDataSourceAccess(connObj,pSQL)
'建立到数据库的连接
On Error Resume Next
'读取本地的WinCC运行数据库名称
Dim DatasourceNameRT,DataConnectionName
Set DatasourceNameRT = hmiRuntime.Tags("@DatasourceNameRT")
DatasourceNameRT.Read

'定义数据库连接字符串
Dim sPro, sDsn,sSer

sPro = "Provider=WinCCOLEDBProvider.1;"

sDsn = "Catalog=" & DatasourceNameRT.Value & ";"

sSer = "Data Source=.WinCC"

DataConnectionName = sPro sDsn sSer
' 定义查询语句字符串
Dim sSQL
sSQL=pSQL

'建立连接
Dim oRs,oCom,conn
Set conn = CreateObject("ADODB.Connection")
Set conn=connObj
conn.ConnectionString = DataConnectionName
conn.CursorLocation = 3
conn.Open
' 创建查询的命令文本
Set oRs = CreateObject("ADODB.Recordset")

Set oCom = CreateObject("ADODB.Command")

oCom.CommandType = 1

Set oCom.ActiveConnection = conn

oCom.CommandText=sSQL
'执行查询
Set oRs = oCom.Execute

'返回结果
Set WinCCDataSourceAccess=oRs

If err.number <> 0 Then

MsgBox "error Code" & Err.Number & "Source:" & Err.Source & "error description" & Err.Description
err.clear

End If

On Error Go to 0

End Function

自定义函数的创建过程为:在WinCC项目管理器中右键点击全局脚本打开VBS全局脚本编辑器项目函数新建函数。具体如下图所示:

通过VBS脚本在ListView控件中显示WinCC的变量记录
图2
3.2 注册Microsoft ListView Control 6.0控件

打开WinCC图形编辑器。在右侧的对象选项板中单击“控件”,选中“ActiveX Control”,点击右键,选择“添加移除”。在弹出菜单中,选择“Microsoft ListView Control 6.0”,点击“OK”确认。

通过VBS脚本在ListView控件中显示WinCC的变量记录
图3

之后,将“Microsoft ListView Control 6.0”拖动到画面编辑器中,并将对象名称设置为Control1。
注意:在脚本中,当定义ListView对象时用到对象名称Control1。详情请参考图1的步骤2。

3.3 添加ListView 控件的列名
在ListView中添加列名,步骤如图1的步骤3。自定义函数AddListViewHeaderColumn(pRecordset, pListView)的具体代码如下所示:
Function AddColumnHeader(pRecordset, pListView)
'添加ListView列名

'用于错误捕获和处理
On Error Resume Next

Dim oRs,columnCount

Set oRs=CreateObject("ADODB.Recordset")

Set oRs=pRecordset

'获取数据库中的列数
columnCount=oRs.Fields.Count

'定义操作的ListView对象
Dim ListViewT

Set ListViewT=pListView
'清空ListView对象的列数
ListViewT.ColumnHeaders.Clear

'用查询的数据库表格列名来为ListView添加列名(*2)
Dim AddColumnIndex

For AddColumnIndex=0 To columnCount-1

ListViewT.ColumnHeaders.Add , , CStr(oRs.Fields(AddColumnIndex).Name)

Next
'发生错误,提示消息框
If err.number <> 0 Then

MsgBox "AddColumnHeader函数报错,Source:" & Err.Source & vbCr & "Error description:" & Err.Description

err.clear

End If

On Error Goto 0

End Function

3.4 填充ListView 控件
在ListView中添加列名,步骤如图1的步骤4。自定义函数FillListView (pRecordset, pListView) 的具体代码如下所示:
Function FillListView(pRecordset,pListView)
'用数据库查询的值填充ListView
On Error Resume Next

'获取查询记录条数
Dim recordsCount,oRs
Set oRs=CreateObject("ADODB.Recordset")
Set oRs=pRecordset
recordsCount=oRs.RecordCount

'定位到第一条记录
If (recordsCount > 0) Then
oRs.MoveFirst

'定义最大的查询条目(*3)
Dim maxLine,n

maxLine = 10
n=0
'填充数据值列
Do While (Not oRs.EOF And n < maxLine)

n = n 1

Dim oItem,ListViewT
Set ListViewT=pListView
Set oItem = ListViewT.ListItems.Add()

oItem.text = oRs.Fields(0).Value

oItem.SubItems(1) = oRs.Fields(1).Value

oItem.SubItems(2) = FormatNumber(oRs.Fields(2).Value, 4)

oItem.SubItems(3) = Hex(oRs.Fields(3).Value)

oItem.SubItems(4) = Hex(oRs.Fields(4).Value)

oRs.MoveNext

Loop

3.5 关闭到归档数据库的连接
关闭与数据库的连接并释放资源,步骤如图1的步骤5。自定义函数WinCCDataSourceClose(pRecordset, connObj)的具体代码如下图所示:
Function WinCCDataSourceClose(pRecordset,connObj)
'关闭数据库连接,释放资源
'获取连接和查询对象
Dim oRs,conn

Set oRs=pRecordset
Set conn=connObj

oRs.Close

Set oRs = Nothing

conn.Close

Set conn = Nothing

End Function

3.6 运行结果
本文档介绍的脚本,其运行结果如下图所示:

通过VBS脚本在ListView控件中显示WinCC的变量记录
图4
3.7 更改代码以满足更广泛的需求
对于不同客户的定制化需求,可以通过修改少量代码实现。
(1) 不同的查询需求,修改sSQL变量的值。
'修改变量sSQL的值
Dim sSQL

sSQL="Tag:R,'ProcessValueArchiveTag1','0000-00-00 00:01:00.000','0000-00-00 00:00:00.000'"

比如,如果需要动态制定查询时间,可以在画面中输入查询日期,然后通过HMIRuntime.Tags(“变量名”)来获得查询条件,再赋值给sSQL。
(2) ListView需要使用不同的列名。
修改函数AddListViewHeaderColumn中的如下内容:
‘用查询的数据库表格列名来为ListView添加列名 (*2)
Dim AddColumnIndex

For AddColumnIndex=0 To columnCount-1

ListViewT.ColumnHeaders.Add , , CStr(oRs.Fields(AddColumnIndex).Name)

Next

(3) ListView需要填充不一样的行数和内容。
修改函数FillListView中的如下内容:
Dim maxLine,n

maxLine = 10 '改变此值,可以更改最大显示的条目数
n=0
'修改填充内容,请修改下面Do While循环中的代码
Do While (Not oRs.EOF And n < maxLine)

n = n 1

Dim oItem,ListViewT
Set ListViewT=pListView
Set oItem = ListViewT.ListItems.Add()

oItem.text = oRs.Fields(0).Value

oItem.SubItems(1) = oRs.Fields(1).Value

oItem.SubItems(2) = FormatNumber(oRs.Fields(2).Value, 4)

oItem.SubItems(3) = Hex(oRs.Fields(3).Value)

oItem.SubItems(4) = Hex(oRs.Fields(4).Value)

oRs.MoveNext

Loop

本文档中提供的脚本尽量通用化,方便客户修改和复用。并加入了错误处理机制,保证脚本的正确运行,并提高了诊断的方便性。

声明:
本文所述的方法为WinCC的高级用法,提供的代码程序仅供用户参考,西门子公司不提供任何调试和热线支持。敬请谅解!

    相关阅读

    电焊机电流调到多少合适,根据焊条大小及焊接对象做调整

    2.5焊条电焊机电流大小应根据焊条的种类来定: 1、一般碳钢焊条焊接电流调到100A左右,不锈钢焊条稍低点。 2、焊方管2.5焊条电流: 60-80A电焊机利用正负两极在瞬间短路时产生的高温电...
    2023-01-09
    电焊机电流调到多少合适,根据焊条大小及焊接对象做调整

    软启动器12个故障代码

    软启动器常见故障问题的故障代码,参考如下: 1、故障代码Err01 故障类容:→断相;说明:主电路任意一相断相。 2、故障代码Err02 故障类容:→过电流;说明:超过额定电流12倍。 3、故...
    2022-11-26

    第一次有人把电流互感器介绍得这么好!

    ...
    2024-10-08
    第一次有人把电流互感器介绍得这么好!

    睡觉要远离的十大电器,长期辐射会致癌,所有人猜不到第一名是它

    辐射这个名词进入普通人的生活时间并不长,但大家对辐射的关注程度并不低,而日常我们接触到的辐射主要来自家用电器,那么到底哪些电器对我们有危害呢? 辐射是否对人有害的标...
    2023-06-11
    睡觉要远离的十大电器,长期辐射会致癌,所有人猜不到第一名是它

    电焊机怎么调,电流与电压调整方法

    电焊机的调整方法,具体参考如下: 1、先把电流旋钮调到最小,把电压旋钮调到最大,试焊一下,不要动电压旋钮,逐步调大电流,直到能正常焊接时停上。 2、反过来,把电流旋钮先...
    2023-01-09
    电焊机怎么调,电流与电压调整方法

    电动车电池看参数的三种方法,轻松查看电动车电池型号

    新买的电动车电池是什么型号的,很多人并不是很清楚,而在需要换电池时搞不清楚型号就会很麻烦,那么电动车电池规格怎么,怎么来识别电动车电池的型号,与电工天下小编一起来...
    2022-11-30

    插座发出滋滋滋的声音是什么原因

    首先最有可能的原因就是电源线与插座接线端子接触不牢固,而造成的虚接,进而产生电弧也就是我们俗称的电火花,就会发出的滋滋声音。 插座内由于质量问题,电源接线柱与插头触...
    2022-11-10
    插座发出滋滋滋的声音是什么原因

    一灯三控开关怎么安装?一灯三控开关接线图解

    一灯三控开关怎么安装怎么安装?设计一灯三控主要是方便我们的生活,就像是我们的卧室和走廊一样,如果一个设计多个开关控制的话使用会比较方便的,就比如说我们的床头位置都...
    2023-06-27
    一灯三控开关怎么安装?一灯三控开关接线图解

    网站栏目