WINCC中VBS如何实现另存为对话框将固定目录下的EXCEL文件默认按当前时间命名(之后可以自己随意命名)保存想要保存的路径中

在网上找了一段打开选择对话框的程序,程序如下
Sub OnLButtonDown(ByVal Item, ByVal Flags, ByVal x, ByVal y)                                   
Dim CDG,WSH,FilePath 
Set CDG=CreateObject("MSCOMDLG.CommonDialog.1")
CDG.MaxFileSize=260
CDG.InitDir="F:\" '设置默认目录
CDG.ShowOpen
FilePath=CDG.FileName ''获取选定文件的完整路径
Set CDG=Nothing '' 释放对象
Set WSH=CreateObject("Wscript.Shell")
WSH.Run "Cmd /C Start """" """ & FilePath & """",0 ''打开选定的文件
Set WSH=Nothing 
运行这段程序没有问题,但是我做了改动想改为另存为对话框发现实现不了功能,改动程序如下
Sub OnLButtonDown(Byval Item, Byval Flags, Byval x, Byval y)                                                                                                
Dim CDG,WSH,FSO,F,FilePath 
Set CDG=CreateObject("MSCOMDLG.CommonDialog.1")
CDG.MaxFileSize=260
CDG.InitDir="D:\" '设置默认目录
CDG.Filter="Excel2007 文件 (*.xlsx)"
CDG.FileName="D:\excel.xls" '需要保存的文件及文件路径 '设置默认文件名
CDG.CancelError = True
CDG.ShowSave
Set CDG=Nothing '' 释放对象
FileCopy "D:\excel.xls", CommonDialog1.FileName '将文件保存到想要保存的的文件夹下
'Set WSH=CreateObject("Wscript.Shell")
'WSH.Run "Cmd /C Start """" """ & FilePath & """",0 ''打开选定的文件
Set WSH=Nothing 
Set F=Nothing
Set FSO=Nothing
Set CDG=Nothing
Set objFSO=Nothing
End Sub
程序执行到FileCopy "D:\excel.xls", CommonDialog1.FileName '将文件保存到想要保存的的文件夹下  这一步就不执行了   麻烦大神给看看哪里出了问题,如何改动,非常感谢

问题补充:
Set CDG=Nothing '''''''' 释放对象(对象被释放了还怎么复制,这段放到后面)
FileCopy "D:\excel.xls", CommonDialog1.FileName(CommonDialog1是什么?程序里没有定义,这里应该是CDG

按照上面的试过也不行

最佳答案

你这段代码真是有意思,第一段的openFile我改成WSH.CreateObject在一个VBS文件里面执行失败,但是放到Wincc里面就成功了,之前我也是碰到这个现象就放弃comdlg这个ocx了,没想到wincc居然可以执行ok。后面你改的save代码有点问题,我在wincc里面改了一下,基本ok,但有个不太爽的地方:save的对话框里面必须输入完整的文件名(带扩展名),我改的save代码如下:
''---------------------------------------------------------------------------------------------------
Sub OnLButtonDown(ByVal Item, ByVal Flags, ByVal x, ByVal y)       
Dim CDG,FSO,F,FilePath 
Set CDG=CreateObject("MSCOMDLG.CommonDialog.1")
FilePath = "C:\excel.xls"
CDG.MaxFileSize=260
CDG.InitDir="C:\" ''设置默认目录
CDG.Filter="Excel2007 文件 (*.xlsx)"
CDG.FileName=FilePath ''需要保存的文件及文件路径 ''设置默认文件名
CDG.CancelError = True
CDG.ShowSave
Set FSO=Createobject("Scripting.FileSystemObject")
Set F=FSO.GetFile(FilePath)
F.copy CDG.FileName ''将文件保存到想要保存的的文件夹下
Set CDG=Nothing '''' 释放对象
Set F=Nothing
Set FSO=Nothing
Set CDG=Nothing
End Sub

提问者对于答案的评价:

原创文章,作者:ximenziask,如若转载,请注明出处:https://www.zhaoplc.com/plc355058.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2021年7月5日 上午2:13
下一篇 2021年7月5日 上午2:13

相关推荐

  • S7400通过路由器TL-R860连接WINCC,上位机是否需要配置工业以太网卡?

    如题 最佳答案 普通网卡也可以CP1613只不过性能比较好 提问者对于答案的评价:谢谢

    SIMATIC WinCC 2018年12月5日
  • 这要怎么办?

    我想装一个ConfigurationTool ,可是提示this application needs excel 2000/xp/…

    SIMATIC WinCC 2019年6月11日
  • 拷贝博图v13,RT start无法启动

    拷贝后的博图v13程序  用wincc RT start 无法启动  程序无法也下载,程序是正常的,博图软件中…

    2021年7月5日
  • wincc7.0 online trendcontrol 连接失败

    wincc7.0 online trendcontrol 连接失败,连接在线变量和归档变量都提示连接不上,什么原因?启动里已经设置变量记录激活 最佳答…

    SIMATIC WinCC 2021年7月5日
  • WINCC 打印作业属性

    里的布局文件里的  已经建好的布局文件  怎么打了黄色问题?我的是64K授权 问题补充:出现了黄色感叹号!打错了。 图片说明:  …

    2017年12月8日
  • wincc监控无法操作

    从工业现场拷贝一个项目,在自己电脑上运行时候发现(没有连接PLC)只要是用C动作来实现的阀门电机给定界面均无法打开,只要是直接连接的就能打开给定界面,不知道C动作与直接连接有什么区…

    SIMATIC WinCC 2021年7月5日
  • 报表返回的记录数

    WINCC中用listview控件显示用户归档记录,连接数据已成功,通过m = oRs.RecordCount检测到有33个数据,为何在ListView控件中显…

    SIMATIC WinCC 2019年6月11日
  • WINCC项目版本转换问题

    新配的电脑基本都是预装WIN10的系统,对软件的版本要求也高了。我这边的现场WINCC版本涉及了5.1,6.0,6.2,7.0,7.3。有没有什么软件或方法能快速转换这些版本?比如…

    SIMATIC WinCC 2021年7月5日
  • wincc开关控件

    用A开关控制B开关的打开后为什么B开关的事件函数不发生 如A开关打开后通过梯形图使B开关也打开。打开A开关,B开关自动打开但是B开事件下的弹出画面函数却没有发生,没有画面…

    2017年5月29日
  • 怎样截取WINCC的画面

    我在WINCC上座了几个画面,在制作使用说明书的时候想截取一张WINCC的画面,请问怎样操作呢? 另外,如果我在另一个项目上想用上一个项目的WINCC画面,怎样移植过去呢…

    SIMATIC WinCC 2019年6月11日

发表回复

登录后才能评论