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

提示:本文不涉及具体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)(http://www.ad.siemens.com.cn/club/bbs/upload/image/20171109/6364581859894549671769836.png)]

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

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

注意:

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

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

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

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值