Excel表格密码忘记处理方法

overme6个月前 (10-17)办公软件教程871
如果你遇到忘记Excel文档密码的情况,希望本文对你有所帮助!

excel表格密码破解方法:

  1、打开您需要破解保护密码的Excel文件;

  2、依次点击菜单栏上的工具—宏—-录制新宏,输入宏名字如:aa;

  3、停止录制(这样得到一个空宏);

  4、依次点击菜单栏上的工具—宏—-宏,选aa,点编辑按钮;

  5、删除窗口中的所有字符(只有几个),替换为下面的内容;

从横线下开始复制

  ——————————————————————————————

  Option Explicit

  Public Sub AllInternalPasswords()

  \’ Breaks worksheet and workbook structure passwords. Bob McCormick

  \’ probably originator of base code algorithm modified for coverage

  \’ of workbook structure / windows passwords and for multiple passwords

  \’

  \’ Norman Harker and JE McGimpsey 27-Dec-2002 (Version 1.1)

  \’ Modified 2003-Apr-04 by JEM: All msgs to constants, and

  \’ eliminate one Exit Sub (Version 1.1.1)

  \’ Reveals hashed passwords NOT original passwords

  Const DBLSPACE As String = vbNewLine & vbNewLine

  Const AUTHORS As String = DBLSPACE & vbNewLine & _

  ”Adapted from Bob McCormick base code by” & _

  ”Norman Harker and JE McGimpsey”

  Const HEADER As String = ”AllInternalPasswords User Message”

  Const VERSION As String = DBLSPACE & ”Version 1.1.1 2003-Apr-04″

  Const REPBACK As String = DBLSPACE & ”Please report failure ” & _

  ”to the microsoft.public.excel.programming newsgroup.”

  Const ALLCLEAR As String = DBLSPACE & ”The workbook should ” & _

  ”now be free of all password protection, so make sure you:” & _

  DBLSPACE & ”SAVE IT NOW!” & DBLSPACE & ”and also” & _

  DBLSPACE & ”BACKUP!, BACKUP!!, BACKUP!!!” & _

  DBLSPACE & ”Also, remember that the password was ” & _

  ”put there for a reason. Don\’t stuff up crucial formulas ” & _

  ”or data.” & DBLSPACE & ”Access and use of some data ” & _

  ”may be an offense. If in doubt, don\’t.”

  Const MSGNOPWORDS1 As String = ”There were no passwords on ” & _

  ”sheets, or workbook structure or windows.” & AUTHORS & VERSION

  Const MSGNOPWORDS2 As String = ”There was no protection to ” & _

  ”workbook structure or windows.” & DBLSPACE & _

  ”Proceeding to unprotect sheets.” & AUTHORS & VERSION

  Const MSGTAKETIME As String = ”After pressing OK button this ” & _

  ”will take some time.” & DBLSPACE & ”Amount of time ” & _

  ”depends on how many different passwords, the ” & _

  ”passwords, and your computer\’s specification.” & DBLSPACE & _

  ”Just be patient! Make me a coffee!” & AUTHORS & VERSION

  Const MSGPWORDFOUND1 As String = ”You had a Worksheet ” & _

  ”Structure or Windows Password set.” & DBLSPACE & _

  ”The password found was: ” & DBLSPACE & ”$$” & DBLSPACE & _

  ”Note it down for potential future use in other workbooks by ” & _

  ”the same person who set this password.” & DBLSPACE & _

  ”Now to check and clear other passwords.” & AUTHORS & VERSION

  Const MSGPWORDFOUND2 As String = ”You had a Worksheet ” & _

  ”password set.” & DBLSPACE & ”The password found was: ” & _

  DBLSPACE & ”$$” & DBLSPACE & ”Note it down for potential ” & _

  ”future use in other workbooks by same person who ” & _

  ”set this password.” & DBLSPACE & ”Now to check and clear ” & _

  ”other passwords.” & AUTHORS & VERSION

  Const MSGONLYONE As String = ”Only structure / windows ” & _

  ”protected with the password that was just found.” & _

  ALLCLEAR & AUTHORS & VERSION & REPBACK

  Dim w1 As Worksheet, w2 As Worksheet

  Dim i As Integer, j As Integer, k As Integer, l As Integer

  Dim m As Integer, n As Integer, i1 As Integer, i2 As Integer

  Dim i3 As Integer, i4 As Integer, i5 As Integer, i6 As Integer

  Dim PWord1 As String

  Dim ShTag As Boolean, WinTag As Boolean

  Application.ScreenUpdating = False

  With ActiveWorkbook

  WinTag = .ProtectStructure Or .ProtectWindows

  End With

  ShTag = False

  For Each w1 In Worksheets

  ShTag = ShTag Or w1.ProtectContents

  Next w1

  If Not ShTag And Not WinTag Then

  MsgBox MSGNOPWORDS1, vbInformation, HEADER

  Exit Sub

  End If

  MsgBox MSGTAKETIME, vbInformation, HEADER

  If Not WinTag Then

  MsgBox MSGNOPWORDS2, vbInformation, HEADER

  Else

  On Error Resume Next

  Do \’dummy do loop

  For i = 65 To 66: For j = 65 To 66: For k = 65 To 66

  For l = 65 To 66: For m = 65 To 66: For i1 = 65 To 66

  For i2 = 65 To 66: For i3 = 65 To 66: For i4 = 65 To 66

  For i5 = 65 To 66: For i6 = 65 To 66: For n = 32 To 126

  With ActiveWorkbook

  .Unprotect Chr(i) & Chr(j) & Chr(k) & _

  Chr(l) & Chr(m) & Chr(i1) & Chr(i2) & _

  Chr(i3) & Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

  If .ProtectStructure = False And _

  .ProtectWindows = False Then

  PWord1 = Chr(i) & Chr(j) & Chr(k) & Chr(l) & _

  Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _

  Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

  MsgBox Application.Substitute(MSGPWORDFOUND1, _

  ”$$”, PWord1), vbInformation, HEADER

  Exit Do \’Bypass all for…nexts

  End If

  End With

  Next: Next: Next: Next: Next: Next

  Next: Next: Next: Next: Next: Next

  Loop Until True

  On Error GoTo 0

  End If

  If WinTag And Not ShTag Then

  MsgBox MSGONLYONE, vbInformation, HEADER

  Exit Sub

  End If

  On Error Resume Next

  For Each w1 In Worksheets

  \’Attempt clearance with PWord1

  w1.Unprotect PWord1

  Next w1

  On Error GoTo 0

  ShTag = False

  For Each w1 In Worksheets

  \’Checks for all clear ShTag triggered to 1 if not.

  ShTag = ShTag Or w1.ProtectContents

  Next w1

  If ShTag Then

  For Each w1 In Worksheets

  With w1

  If .ProtectContents Then

  On Error Resume Next

  Do \’Dummy do loop

  For i = 65 To 66: For j = 65 To 66: For k = 65 To 66

  For l = 65 To 66: For m = 65 To 66: For i1 = 65 To 66

  For i2 = 65 To 66: For i3 = 65 To 66: For i4 = 65 To 66

  For i5 = 65 To 66: For i6 = 65 To 66: For n = 32 To 126

  .Unprotect Chr(i) & Chr(j) & Chr(k) & _

  Chr(l) & Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _

  Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

  If Not .ProtectContents Then

  PWord1 = Chr(i) & Chr(j) & Chr(k) & Chr(l) & _

  Chr(m) & Chr(i1) & Chr(i2) & Chr(i3) & _

  Chr(i4) & Chr(i5) & Chr(i6) & Chr(n)

  MsgBox Application.Substitute(MSGPWORDFOUND2, _

  ”$$”, PWord1), vbInformation, HEADER

  \’leverage finding Pword by trying on other sheets

  For Each w2 In Worksheets

  w2.Unprotect PWord1

  Next w2

  Exit Do \’Bypass all for…nexts

  End If

  Next: Next: Next: Next: Next: Next

  Next: Next: Next: Next: Next: Next

  Loop Until True

  On Error GoTo 0

  End If

  End With

  Next w1

  End If

  MsgBox ALLCLEAR & AUTHORS & VERSION & REPBACK, vbInformation, HEADER

  End Sub

  —————————————————————————————–

  复制到横线以上

  6、关闭编辑窗口;

  7、依次点击菜单栏上的工具—宏—–宏,选AllInternalPasswords,运行,确定两次;

  等一会,就会出现以下对话框:这就是Excel密码对应的原始密码(此密码和原先设置的密码都能打开此文档。如果是别人的文档,你又想恢复密码设置,就可以用此密码进行保护,他就能用他设置的密码打开,你可以试试,很有趣的。字母一定要大写)。

相关文章


		office2013如何取消excel的拼写检查以及自动更正

office2013如何取消excel的拼写检查以及自动更正

学习办公中,Excel是非常常用且实用的办公软件,深受大家的欢迎。Excel自身集成了拼写检查自动校正功能,今天有朋友问我Excel中输入简称STPO,怎么会自动变为STOP呢。 其实这就是拼写检...


		Excel按enter键朗读单元格内容

Excel按enter键朗读单元格内容

最近同事使用Excel按Enter键后,系统会自动朗读播放内容。开始以为是搜狗输入法的功能,后面弄清楚了,原来是Excel集成的朗读单元格功能。 Excel朗读单元格功能,如下图所示,点击该图标激...


		怎么在Excel中输入10以上的带圈数字

怎么在Excel中输入10以上的带圈数字

如下图所示,使用Excel制作资料时,可能会遇到需要插入带圈数字序号的情况。 在想要插入带圈数字的单元格,点击插入符号,子集选择带括号的字母数字,下方就出现了带圈数字序号,选择想要的数字,点击插入...


		Excel中20以上带圈数字输入方法

Excel中20以上带圈数字输入方法

很多人在使用Excel时,遇到需要输入带圈数字的情况,都可以通过插入->符号,输入10以内或者20以内的带圈数字。 很少遇到需要输入20以上带圈数字的情况,如果遇到了,该怎么输入呢? 以下分...


		Excel选项按钮的值及单元格链接

Excel选项按钮的值及单元格链接

使用Excel选项按钮,当然需要了解其功能。上一篇文章分享了Excel插入选项按钮的方法,本文分享选项按钮的相关应用说明: ① 鼠标选中选项按钮控件右键,选择编辑控件格式。 ② 进入选项按钮控...


		Excel如何打开Visual basic代码编辑页面

Excel如何打开Visual basic代码编辑页面

Visual Basic(简称VB)是Microsoft公司开发的一种基于对象的程序设计语言,是结构化、模块化、面向对象、包含协助开发环境的事件驱动为机制的可视化程序设计语言。 Excel中集成...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。