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

相关推荐

  • SQL Server2005安装问题

    在安装SQL Server2005(WinCC6.2 光盘带的)时,出现提示:The Windows Installer serv…

    SIMATIC WinCC 2017年12月8日
  • WINCC C脚本的入门问题

    我是新学的C脚本 请问 : 1 。 要使用MASSAGEBOX() 要引用哪个DLL或者头文件 ?DLL+头文…

    SIMATIC WinCC 2019年6月11日
  • 西门子触摸屏SMART V3

    程序下载不了。IP地址等都已设置,仍显示没有选择通道。求教 问题补充:以太网复选框已选,还是下载不了 图片说明:        &…

    2021年7月5日
  • MP277 的OS版本如何从1.2升级到1.6

    大家好,我是个小白, 我们厂有个MP277-10的控制屏,之前通过U盘直接插在控制屏上进行了程序备份,这次因为控制屏坏了,我们更换了一个新屏,本来通过U盘恢复备份出现兼容…

    SIMATIC WinCC 2020年11月1日
  • 使用动态对话框改变背景颜色

    使用一个圆的动态对话框功能改变背景颜色:“表达式/公式”内做两个bool量的减法(见附图)。数据类型选择“模拟量”,然后在对应不同结果选择不同的颜色。等于-1显示红色;0对应青色,…

    2020年11月1日
  • wincc v7.4 图形编辑器打不开

    wincc v7.4之前都用的好好的,昨天打开一个画面时一直卡在那里了,我就从资源管理器里把wincc推出了,今天早上来用的时候,发现双击变量编辑器没反映,打开一个画面,…

    SIMATIC WinCC 2021年7月5日
  • wincc flexible 外部变量

    各位大侠好,我是一个新手,请教大家一个问题,我组态阀门时使用了外部变量Q1.0,cpu是314系列的,在不上传程序时wincc画面正常阀门也都显示,一旦上传程序后,所有阀门都不显示…

    SIMATIC WinCC 2019年6月10日
  • win7专业版64位装好step7 v5.5正版授权后打开提示未找到密钥

    在正版win10家庭版系统上安装VMware虚拟机,虚拟机上装win7专业版64位系统(非ghost版本)。在该虚拟系统内装了2012年买了一直未拆封的正版step7 v…

    2021年7月5日
  • wincc外部变量没有访问到PLC

    第一次用wincc!我的机器装有step75.4,wincc6.2,CP5611卡。现在通过step7对于下位机cpu315-2DP的编程完成!但现在wincc访问不到下位机!具体…

    SIMATIC WinCC 2017年7月25日
  • 如何卸载wicc授权

    如何卸载wicc授权 最佳答案 1.楼主可以通过授权管理器(Automation License Manager)把授权转移到其它盘符或者U盘中。 2…

    SIMATIC WinCC 2019年6月11日

发表回复

登录后才能评论