WinCC变量归档的历史数据查询结果输出PDF文件的一个方法

已锁定

aididr

  • 帖子

    5
  • 精华

    0
  • 被关注

    4

论坛等级:游士

注册时间:2012-10-25

普通 普通 如何晋级?

WinCC变量归档的历史数据查询结果输出PDF文件的一个方法

4241

1

2017-11-09 09:54:16

提示:本文不涉及具体VBS实现代码,因为这些代码在网上可随意找到(不要只做一个伸手党),本文仅提供初学者一个思路来实现历史数据查询结果直接输出PDF。

   曾经看过其他软件可以提供用户历史数据查询生成后直接输出成PDF文件保存在上位机硬盘里,这样数据是不容易在常规条件下修改。但是WinCC在变量归档查询的时候,只能通过打印机和脚本实现。

   对于计算机语言比较弱的新手,还要实现这样的功能,就有点困难。通过自己在之前的练习,发现一个简单实用的方法:通过VBS用ADODB通过OLEDB的方式连接到数据库并查询返回到页面控件(ListView或者MSFlexGrid等)内显示,再写入Excel表格,通过Excel表格的宏保存成PDF文件(在宏里面可设置保存路径),同时放弃Excel表格的存盘。这样数据查询借助Excel表格实现PDF的保存,但是又不会在Excel表格内留下数据,防止数据被轻易修改。

具体实现步骤如下:

1、在页面中添加2个按钮(Button1、Button2)和查询起始、终止日期(DatePicker)控件,一个ListView控件或者MSFlexGrid控件。

2、做一个启用宏的Excel表格,并写入VBA宏。宏功能是将表格保存到指定路径,命名规则自定义,要保证每次命名不与已有文件重名,否则直接覆盖掉。

2、在按钮(Button1)内做好VBS脚本,也可以用C脚本完成。脚本功能实现按照日期及时间间隔查询变量归档数据,并返回到ListView控件或MSFlexGrid控件内,实现查询。

3、在按钮(Button2)内做好VBS脚本。脚本功能实现将ListView控件或MSFlexGrid控件的数据写入Excel表格并调用Excel表格内步骤2写好的那个宏,同时放弃存盘Excel表格数据!此过程设置写入Excel过程中表格不可见,即所有操作在后台运行,效果就是按下按钮(Button2)指定路径会出现生成的PDF文件。

4、保存前3个步骤的工作(如果觉得格式不好,可以在VBS里面修改报表格式等)。


附 一张完成输出PDF文件的效果:

(因为变量模仿是在11月7号做的时间比较长,所有就查询了11月7日的数据。)



注意:

   目前测试这种方法保存成PDF的效率还可以,只是查询的过程会有迟缓。

   3000多条数据在查询的时候可能需要20s到1分钟不等,但数据查询完成后通过写入Excel保存成PDF的时间大约2、3秒即完成,不得不说,WinCC和Office的连接速度还是比较快。


本人初学者,目前刚成功测试这样的方法,与大家分享一二,如果大家还有什么其他方法,可以留言。欢迎大家点评与指导。



WinCC变量归档的历史数据查询结果输出PDF文件的一个方法 已锁定
编辑推荐: 关闭

请填写推广理由:

本版热门话题

SIMATIC WinCC / Panel

共有31077条技术帖

相关推荐

热门标签

相关帖子推荐

guzhang

恭喜,你发布的帖子

评为精华帖!

快扫描右侧二维码晒一晒吧!

再发帖或跟帖交流2条,就能晋升VIP啦!开启更多专属权限!

top
您收到0封站内信:
×
×
信息提示
很抱歉!您所访问的页面不存在,或网址发生了变化,请稍后再试。