提示:本文不涉及具体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的连接速度还是比较快。

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

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

  1. 输出pdf文件的一个简单方法

    最近尝试使用pdflib输出pdf文档,但是pdflib的方法很多,要将打印输出与pdf匹配,需要编写很多代码,而且一旦需要修改,也是个麻烦事,所以就想了个偷懒的办法,如下: 1.在项目中加入pdfl ...

  2. Rstudio Markdown中文输出PDF文件

    注意首先安装R的rticles文档模板包 Rstudio Markdown中文输出PDF文件:需要下载安装Tex文档编译器(texlive 或MikTex), 也可以运行以下代码,安装谢益辉提供的代码 ...

  3. 标签打印软件输出PDF文件过大时如何解决?

    在用标签打印软件制作标签输出PDF文件时,如果数据过多可能会出现输出的PDF文件过大,这种情况如何解决呢?在标签打印软件中,输出PDF文件时可以对PDF文件进行压缩和拆分,压缩方式有六种,分别为:默认 ...

  4. 通过安装虚拟打印机输出PDF文件

    前两天,用FastReport输出pdf文件,在查资料时候,无意看到可通过安装一个虚拟的打印机,把任何支持打印的软件的输出,都输出为pdf文件.比如把word,excel...等等都可以转化成pdf文 ...

  5. cad怎么输出pdf文件?

    因为工作的需要,我们经常要把AutoCAD图转换PDF文件,网上有很多的方法,大多数都是麻烦的,CAD怎么输出PDF文件呢?下面我就来简单的介绍一下. 第一步:在百度浏览器搜搜迅捷caj转换器,然后找 ...

  6. 如何将CSDN文档输出PDF文件?

    简 介: 根据生成文档的需要,在CSDN上寻找一些介绍将MARKDOWN文档生成PDF博文.根据他们介绍的方法,测试打印的效果.特别是对于CSDN新增加的一些显示元素的清理,可以生成更加干净完整的PD ...

  7. 【VBA研究】输出PDF文件合并时出错

    作者:iamlaosong 在做一个打印通知单的工具时(这个工具已经做过很多个,技术基本一样),输出的多个PDF文件合并时出错,单个PDF文件打开没有问题. 合并其他文件没有问题,那问题只能是这些单个 ...

  8. Springboot输出PDF文件

    前言 有个人(死需求)跑过来跟你说,这些都给我输出成报告,pdf格式的,所以就有了下面这个,做一下笔记,以后有用直接过来拿.在网上找了一下,发现大家都是在用itext. iText是著名的开放项目,是 ...

  9. plsql学习范例--使用utl_file包将查询结果输出到文件中

    最近在开发过程中需要根据查询结果生成一个HTML文件,用到了utl_file包,对于该包的使用,简单做了一下测试: --先在数据中创建directory并授权: SQL> create or r ...

最新文章

  1. mysql普通索引标记_Mysql 索引
  2. 分布式事务 GTS 的价值和原理浅析
  3. ACM寒假训练第二周总结
  4. 9个杰出的免费 WordPress 主题
  5. IBM确定公司未来存储技术发展方向
  6. [原]SDL开发教程
  7. Hadoop学习笔记—11.MapReduce中的排序和分组
  8. android and javascript
  9. DJ轮回舞曲网下载教程
  10. 如何用原型体现你的专业度?
  11. IO、NIO、AIO
  12. (转载)js对象原来也有类、实例属性和原型属性
  13. 编译安装LAMP对其性能压力测试
  14. 新春测 kinect motor
  15. ubuntu 安装node.js
  16. 密码学基础(三):非对称加密(RSA算法原理)
  17. 机械零件设计手册_NASA Fastener Design Manual 紧固件设计手册 - 翻译 2/14
  18. 5G网络演进行业及市场发展需求
  19. 终于搞懂了回车与换行的区别
  20. JTA transaction unexpectedly rolled back (maybe due to a timeout)

热门文章

  1. ABAP 之ALV展示及下钻弹窗数据页面
  2. 最齐全的支付宝小程序支付【详细】
  3. 《html5+css3课程 前端开发项目实战》完整版
  4. java基于ssm的 大学生健康管理系统
  5. prometheus聚合运算
  6. matlab信号仿真模型,对Matlab单边带信号处理得到生动的仿真模型
  7. Tomcat进程假死问题排查
  8. 支付宝app支付java后台流程demo
  9. 2022最新蚂蚁金服Java岗面试题库(整理版)
  10. 梦幻诛仙linux系统启动命令,求一波梦幻诛仙GM指令