技术分享
WinCC变量归档的历史数据查询结果输出PDF文件的一个方法
2021-06-08
提示:本文不涉及具体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里面修改报表格式等)。
[外链图片转存失败(img-2OL5ViK2-1563433549012)
附 一张完成输出PDF文件的效果:
(因为变量模仿是在11月7号做的时间比较长,所有就查询了11月7日的数据。)
注意:
目前测试这种方法保存成PDF的效率还可以,只是查询的过程会有迟缓。
3000多条数据在查询的时候可能需要20s到1分钟不等,但数据查询完成后通过写入Excel保存成PDF的时间大约2、3秒即完成,不得不说,WinCC和Office的连接速度还是比较快。
本人初学者,目前刚成功测试这样的方法,与大家分享一二,如果大家还有什么其他方法,可以留言。欢迎大家点评与指导。
- 标签:
-
云计算