首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VBA InputBox Prompts两次

VBA InputBox Prompts两次
EN

Stack Overflow用户
提问于 2015-09-02 20:43:54
回答 2查看 793关注 0票数 1

我有一个简单的脚本,在关闭工作簿之前需要密码(以防止意外关闭),但是如果输入正确的关键字,InputBox将重新打开。我已经创建了以下脚本的多个迭代,但我无法解决它。

代码语言:javascript
复制
Sub Workbook_BeforeClose(Cancel As Boolean)

If InputBox("Please enter the password to close the workbook.") <> "pa55word" Then
    MsgBox ("Incorrect password.  Please try again")
    Cancel = True
    Exit Sub
Else
    GoTo GoToClose
End If

GoToClose:
ThisWorkbook.Close SaveChanges:=False

End Sub
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-09-03 01:23:21

如果你像这样编码:

  • 如果密码没有第二次关闭,代码就会继续保存工作簿。
  • 前面的ThisWorkbook.Saved告诉Excel工作簿已经完全更新,所以不会有您想保存消息的情况--也就是说,它执行与ThisWorkbook.Close SaveChanges:=FalseFalse部分相同的任务,而现有的保存事件关闭了工作簿。

重合件

代码语言:javascript
复制
Sub Workbook_BeforeClose(Cancel As Boolean)

ThisWorkbook.Saved = True
If InputBox("Please enter the password to close the workbook.") <> "pa55word" Then
     MsgBox ("Incorrect password.  Please try again")
     Cancel = True
End If

End Sub
票数 0
EN

Stack Overflow用户

发布于 2015-09-02 20:47:25

关闭之前禁用事件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32362754

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档