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

相关推荐

  • WINCC脚本是用C语言和VB语言写的呢的

    WINCC脚本是用C语言和VB语言写的呢,我想学脚本语言。不知道哪个语言用的比较广泛,方便以后碰到非西门子软件后,他们的脚本语言都是用这一种语言写的,我就不用在重新学习其他语言了。…

    SIMATIC WinCC 2018年12月2日
  • 依然PLC与WINCC的通讯问题

    昨天在这里问了一个关于PLC与WINCC的通讯问题。得到了很多启发,小弟实在愚昧还是没有能解决问题。后来乱搞一通,把S7装上了,结果今天一试竟然通了,小弟这就奇怪了。为什么会通呢?…

    SIMATIC WinCC 2019年6月11日
  • TAG:R,'只能按时间查询吗?

    能不能按照一个变量的值查询? 如按照在一个时间段内 tag = 1的时候的数据?或者直接查询 tag = 1的…

    SIMATIC WinCC 2021年7月5日
  • 请教用户归档使用方法

    是这样,项目有大概10种不同的运行工艺曲线。每种曲线给定一个编号。我想将所有曲线都存入用户归档,使用时根据编号调用。每种曲线有5个参数,共有12个步骤。也就是整个曲线有60个变量。…

    SIMATIC WinCC 2019年6月11日
  • 用C语言写 WINCC中按钮启动会弹出对话框

    用C语言写—–在WINCC中,画面中做了按钮,如果按下按钮便会弹出对话框来让自己选择是否想确定刚才的选择或者可以是取消。  本人不想用隐藏的按钮结合了实现…

    SIMATIC WinCC 2019年6月10日
  • 时间的显示

    怎么才能在WINCC界面中显示时间 我在空间里面只找到了个指针指示的图标,怎么样才能以数字的形式显示,谢谢各位大侠。 最佳答案 WinCC画面中显示时间有多种做法:1,最…

    SIMATIC WinCC 2019年6月11日
  • WIN7操作系统的操作站,WINCC项目怎么复制使用?

    我厂DCS操作站已经从XP的系统升级为WIN7操作系统,现一台运行中的操作站硬盘坏需要更换一台主机。现备机软件已经装好,但是没有WINCC运行项目,其WINCC项目怎么复制、使用呢…

    SIMATIC WinCC 2017年5月28日
  • S7-200和wincc通讯

    我要把一个S7-200和wincc连接起来,距离大概是500-600米,甲方不走光纤要用网线延长器应该怎么通讯。200站有CP243-1模块,我想用pc  ac…

    SIMATIC WinCC 2019年6月11日
  • 用WINCC做设备远程监控

    现在有台设备,维修人员要在维修组用电脑显示设备的运行状态及故障信息,要求用WICC软件来做,请问需要WINCC那些装件 问题补充:设备PLC是三菱FX5U的,HMI是维纶的 最佳答…

    SIMATIC WinCC 2021年7月5日
  • 怎么知道运行的WINCC是属哪个项目的(项目管理器已关闭)?

    在D盘上放在好多个wincc项目,(每次更改项目后都重新保留),现在只有运行界面,项目管理器已关闭,但不知正在运行的是属哪个项目的? 也在D盘上对一些重命名的方法看看是否…

    SIMATIC WinCC 2019年6月11日

发表回复

登录后才能评论