用VBA取消EXCEL文件VBA保护密码。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用VBA取消EXCEL文件VBA保护密码。相关的知识,希望对你有一定的参考价值。

我已经知道EXCEL_B 文件的VBA保护密码。

如何在EXCEL_A文件里 用VBA 取消EXCEL_B 文件的VBA保护密码。

参考技术A 最标准的方法就是直接输入密码,然后解密,保存。

如果有宏代码的话:
1、录制宏,随便点下鼠标,然后停止。
2、打开宏编辑器,将你的VBA代码完全覆盖编辑器里刚录制的那些代码。
3、打开需要去除保护的excel,按ALT+F8运行宏。大概10多秒吧,就好了。本回答被提问者和网友采纳
参考技术B 这个我知道,首先workbooks.Open(文件名,,,,password),用带密码参数的open打开文件,然后用workbooks("xxx").unprotect取消密码即可。。 参考技术C 立即窗口输入取消密码代码,就这么简单

VBA 宏文件源代码密码解除

VBA Project密码解除
第一种方法详细步骤参考:
以下VBA代码是第二种方法

使用本代码之前需要将需要解除密码保护的含有宏的Excel文件(如果是xlsm文件,需要先另存为97-03版的xls文件)关闭新建一个Excel工作簿,Alt+F11 打开VBA编辑器,新建一个模块 ,复制以下代码移除VBA编码保护
Sub MoveProtect()
    Dim FileName As String
    FileName = Application.GetOpenFilename("Excel文件(*.xls & *.xla),*.xls;*.xla", , "VBA破解")
    If FileName = CStr(False) Then
       Exit Sub
    Else
       VBAPassword FileName, False
    End If
End Sub
 
设置VBA编码保护
Sub SetProtect()
    Dim FileName As String
    FileName = Application.GetOpenFilename("Excel文件(*.xls & *.xla),*.xls;*.xla", , "VBA破解")
    If FileName = CStr(False) Then
       Exit Sub
    Else
       VBAPassword FileName, True
    End If
End Sub
 
Private Function VBAPassword(FileName As String, Optional Protect As Boolean = False)
      If Dir(FileName) = "" Then
         Exit Function
      Else
         FileCopy FileName, FileName & ".bak"
      End If
 
      Dim GetData As String * 5
      Open FileName For Binary As #1
      Dim CMGs As Long
      Dim DPBo As Long
      For i = 1 To LOF(1)
          Get #1, i, GetData
          If GetData = "CMG=""" Then CMGs = i
          If GetData = "[Host" Then DPBo = i - 2: Exit For
      Next
      If CMGs = 0 Then
         MsgBox "请先对VBA编码设置一个保护密码...", 32, "提示"
         Exit Function
      End If
      If Protect = False Then
         Dim St As String * 2
         Dim s20 As String * 1
         取得一个0D0A十六进制字串
         Get #1, CMGs - 2, St
         取得一个20十六制字串
         Get #1, DPBo + 16, s20
         替换加密部份机码
         For i = CMGs To DPBo Step 2
             Put #1, i, St
         Next
         加入不配对符号
         If (DPBo - CMGs) Mod 2 <> 0 Then
            Put #1, DPBo + 1, s20
         End If
         MsgBox "文件解密成功......", 32, "提示"
      Else
         Dim MMs As String * 5
         MMs = "DPB="""
         Put #1, CMGs, MMs
         MsgBox "对文件特殊加密成功......", 32, "提示"
      End If
      Close #1
End Function
 

 

以上是关于用VBA取消EXCEL文件VBA保护密码。的主要内容,如果未能解决你的问题,请参考以下文章

我需要在 Excel 文件中打开受密码保护的 VBA 项目 [重复]

VBA密码保护Excel工作簿而不保存

EXCEL VBA 隐藏了工作表,加密的,如何显示或破解

如何去除Excel的VBA工程密码及工作表保护密码

如何去除Excel的VBA工程密码及工作表保护密码

VBA取消工作表或工作薄密码保护