Excel2013教程】如何绿色vba工程密码

[复制链接]
查看: 213|回复: 0

7万

主题

-3

回帖

5993

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
5993
发表于 2018-1-9 07:41:02 | 显示全部楼层 |阅读模式
本人经常从网上下载别人的一些Excel学习vba编码,不过有些人为了避免别人盗用所以给代码加了密码,其实这个密码绿化起来很假单,下面我就跟大家分享一下如何绿化vba工程代码:

wps0r2dfrs5.jpg

wps0r2dfrs5.jpg

  • 将你要绿化的Excel文件关闭,切记一定要关闭呀!然后新建一个Excel文件

    3pgqkxi1c1a.jpg

    3pgqkxi1c1a.jpg
  • 打开新建的这个Excel,按下alt+F11,打开vb界面,新建一个模块,如图所示

    vcvkg3wx53p.jpg

    vcvkg3wx53p.jpg
  • 将代码复制到这个模块中,代码如下:
    Private Sub VBAPassword() '你要解保护的Excel文件路径
    Filename = Application.GetOpenFilename("Excel文件(*.xls & *.xla & *.xlt),*.xls;*.xla;*.xlt", , "VBA绿化")
    If Dir(Filename) = "" Then
    MsgBox "没找到相关文件,清重新设置。"
    Exit Sub
    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 Sub
    End If
    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, "提示"
    Close #1
    End Sub

    0je3b0xgeoc.jpg

    0je3b0xgeoc.jpg
  • 然后点击运行按钮,如图所示,绿色的小三角就是

    q4hbpcoeumz.jpg

    q4hbpcoeumz.jpg
  • 你会看到,打开了一个文件夹,找到我们要绿化的这个文件,然后点击打开

    ozlpmzm1odx.jpg

    ozlpmzm1odx.jpg
  • 稍等几分钟你就会看到绿化成功的提示了

    5umaiimdkry.jpg

    5umaiimdkry.jpg
  • 再次打开你要绿化的这个文件,你会看到这里已经可以查看代码了哈哈

    bmrw3el2tus.jpg

    bmrw3el2tus.jpg

  • 您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    精彩图文
    在线客服(工作时间:9:00-22:00)
    186-108-10699
    老徐微信

    Copyright   ©2018-2022  我的植物  Powered by©Discuz!  技术支持:老徐    ( 京ICP备15066774号-2 )