拾柒-VBA 给 Excel Worksheet 上锁

这个主要是记录给我为公司写的小宏,都什么年代了,还写 VB宏 ,我觉得绝望。

主要在之前的基础上实现了两个功能:

1. 在查询数据的时候把数据内容 Sheet 显示

因为又要把整个 Excel 放在公共盘,又不能把内容直接给别人看,这是闹哪样?

不过还是这样吧,做了吧,当作是为了工资。

首先我有一个 SheetDBR ,这个 Sheet 就是数据源,在平时要隐藏起来,而因为隐藏的时候是更新和读取不了数据的,所以要展开这个 Sheet ,这个好做,代码是:

Sub subHideDBR()
    Sheets("DBR").Select
    ActiveWindow.SelectedSheets.Visible = False

End Sub

Sub subShowDBR()
    Sheets("DBR").Visible = True
End Sub

完成,完事。

2.在平日要把 Sheet 上锁,用宏的时候打开

这个其实在集团下发的 Sheet 上面有这个功能,但因为集团的数据我不敢带回家(奶奶的,连集团都还是用 Excel 宏,有意义吗?什么年代了?),所以就找资料吧。


Const strBookPW As String = "Shit"
Const strSheetPW As String = "Damn"

'锁整个工作本'
Sub subLockBook()
    ActiveWorkbook.Protect strBookPW, Structure:=True, Windows:=False
End Sub

'解锁整个工作本'
Sub subUnLockBook()
    ActiveWorkbook.Unprotect strBookPW
End Sub

'锁 Sheet'
Sub subLockSheet()
    ActiveSheet.Protect DrawingObjects:=False, Contents:=True, Scenarios:= _
        False, AllowFormattingCells:=True, AllowFormattingColumns:=True, _
        AllowFormattingRows:=True, Password:=strSheetPW
End Sub

'解锁 Sheet'
Sub subUnLockSheet()
    ActiveSheet.Unprotect Password:=strSheetPW
End Sub

最后顺便在 Excel 工程中的 ThisWorkbook 对象内加入:

Private Sub Workbook_Open()
    Call subLockBook
    Sheets("Trend Input").Select
    Call subLockSheet
End Sub

方便在打开文件时对文件进行锁。