excel 2010 Workbook_BeforeSave中弹出另存为窗口后保存不了

lubin520520zhuwen 2013-01-29 04:23:27
我在excel 2010中写了如下的代码,为了点击save后弹出save as对话框,并且命名文件.
但是发现点了弹出框的save后并没有保存,为什么?

Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
Dim Name As String
With ThisWorkbook
Name = Worksheets("Sheet1").Range("B7").Value
Dim dlgSaveAs As FileDialog
'Set the dialog type
Set dlgSaveAs = Application.FileDialog(msoFileDialogSaveAs)
With dlgSaveAs
.InitialFileName = Name
.FilterIndex = 2
'Display the dialog
.Show
End With
End With
End Sub


如果我再.Show后面增加.Execute的话,执行会报错
...全文
515 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
lubin520520zhuwen 2013-01-30
  • 打赏
  • 举报
回复
可不可以自己添加个保存按扭 不使用ctrl+s 或者为有保存功能的宏添加个快捷键 ? 是不是用save这个功能不太好搞? 或者为有保存功能的宏添加个快捷键 ? 这个不会。 其实我这个excel只是个模板,目的是作为share point站点里的文档库模板,我可以创建基于这个模板的新的文档,加个保存按钮不符合我的要求的,我想做的就是点击save后弹出框里自动命名文件名,点弹出框的保存就保存文件了。
mnxm 2013-01-30
  • 打赏
  • 举报
回复
可不可以自己添加个保存按扭 不使用ctrl+s 或者为有保存功能的宏添加个快捷键
lubin520520zhuwen 2013-01-29
  • 打赏
  • 举报
回复
那楼上的,我的代码需要移到普通的函数中 ,比如Sub b() 吗? 那我还需要怎么做才能实现我的需求呢?
mnxm 2013-01-29
  • 打赏
  • 举报
回复
上面说的不对 添加Execute后出错的原因是 代码中保存动作执行完后 当前打开的工作薄名字已经变成保存的文件 而你这个函数是在原文件保存前执行的 执行完后还需要进行原文件的保存动作 此时打开的工作薄已经不是源文件 所以无法对源文件进行保存 从而出错 所以你的代码不能放在Workbook_BeforeSave中
mnxm 2013-01-29
  • 打赏
  • 举报
回复

    Dim Name As String
    With ThisWorkbook
        Name = Worksheets("Sheet1").Range("B7").Value
        Dim dlgSaveAs As FileDialog
        'Set the dialog type
        Set dlgSaveAs = Application.FileDialog(msoFileDialogSaveAs)
        With dlgSaveAs
            .InitialFileName = Name
            .FilterIndex = 2
            'Display the dialog
            .Show                        
        End With
    End With
是因为没有Execute而没有保存 添加Execute后 可以保存 但是有个问题 执行Execute时文件也进行了保存动作 还会触发Workbook_BeforeSave这个函数 所以文件出错想不出错的话 把代码移动到普通的函数中

Sub b()
    Dim Name As String
    With ThisWorkbook
        Name = Worksheets("Sheet1").Range("B7").Value
        Dim dlgSaveAs As FileDialog
        'Set the dialog type
        Set dlgSaveAs = Application.FileDialog(msoFileDialogSaveAs)
        With dlgSaveAs
            .InitialFileName = Name
            .FilterIndex = 2
            'Display the dialog
            .Show
            .Execute
            
        End With
    End With
End Sub
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

5,174

社区成员

发帖
与我相关
我的任务
社区描述
其他开发语言 Office开发/ VBA
社区管理员
  • Office开发/ VBA社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧