当前位置:  开发笔记 > 后端 > 正文

保护Excel中的单元格,但允许通过VBA脚本修改这些单元格

如何解决《保护Excel中的单元格,但允许通过VBA脚本修改这些单元格》经验,为你挑选了2个好方法。

我正在使用Excel,其中某些字段允许用户输入,其他单元格将受到保护.我使用过工具保护表,但是在执行此操作后,我无法更改VBA脚本中的值.我需要限制工作表以停止用户输入,同时允许VBA代码根据某些计算更改单元格值.



1> Joe..:

尝试使用

Worksheet.Protect "Password", UserInterfaceOnly := True

如果UserInterfaceOnly参数设置为true,则VBA代码可以修改受保护的单元格.



2> Robert Mearn..:

您可以通过执行这些操作来通过代码修改工作表

保护解除

修改

保护

在代码中,这将是:

Sub UnProtect_Modify_Protect()

  ThisWorkbook.Worksheets("Sheet1").Unprotect Password:="Password"
'Unprotect

  ThisWorkbook.ActiveSheet.Range("A1").FormulaR1C1 = "Changed"
'Modify

  ThisWorkbook.Worksheets("Sheet1").Protect Password:="Password"
'Protect

End Sub

此方法的缺点是,如果代码被中断并且错误处理没有捕获它,则工作表可能处于不受保护的状态.

通过采取这些行动可以改进代码

重新保护

修改

执行此操作的代码将是:

Sub Re-Protect_Modify()

ThisWorkbook.Worksheets("Sheet1").Protect Password:="Password", _
 UserInterfaceOnly:=True
'Protect, even if already protected

  ThisWorkbook.ActiveSheet.Range("A1").FormulaR1C1 = "Changed"
'Modify

End Sub

此代码更新了工作表上的保护,但"UserInterfaceOnly"设置为true.这允许VBA代码修改工作表,同时通过UI保护工作表免受用户输入,即使执行被中断.

关闭并重新打开工作簿时,此设置将丢失.工作表保护仍然保持不变.

因此,"重新保护"代码需要包含在尝试修改工作表的任何过程的开头,或者只能在打开工作簿时运行一次.

推荐阅读
围脖上的博博_771
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有