Option ExplicitPublicSub AllInternalPasswords()' 中断工作表和工作簿结构密码' 算法创始人Bob McCormick' Norman Harker / JE McGimpsey 2002年12月27日(1.1版)' 2003-Apr-04修改:所有msg为常量' 显示哈希密码而不是原始密码Const DBLSPACE AsString= vbNewLine & vbNewLineConst AUTHORS AsString= DBLSPACE & vbNewLine &"Adapted from Bob McCormick base code by"&"Norman Harker and JE McGimpsey"Const HEADER AsString="AllInternalPasswords User Message"Const VERSION AsString= DBLSPACE &"Version 1.1.1 2003-Apr-04"Const REPBACK AsString= DBLSPACE &"Please report failure "&"to the microsoft.public.excel.programming newsgroup."Const ALLCLEAR AsString= 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 AsString="There were no passwords on "&"sheets, or workbook structure or windows."& AUTHORS & VERSIONConst MSGNOPWORDS2 AsString="There was no protection to "&"workbook structure or windows."& DBLSPACE &"Proceeding to unprotect sheets."& AUTHORS & VERSIONConst MSGTAKETIME AsString="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 & VERSIONConst MSGPWORDFOUND1 AsString="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 & VERSIONConst MSGPWORDFOUND2 AsString="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 & VERSIONConst MSGONLYONE AsString="Only structure / windows "&"protected with the password that was just found."& ALLCLEAR & AUTHORS & VERSION & REPBACKDim w1 As Worksheet, w2 As WorksheetDim i AsInteger, j AsInteger, k AsInteger, l AsIntegerDim m AsInteger, n AsInteger, i1 AsInteger, i2 AsIntegerDim i3 AsInteger, i4 AsInteger, i5 AsInteger, i6 AsIntegerDim PWord1 AsStringDim ShTag AsBoolean, WinTag AsBooleanApplication.ScreenUpdating =FalseWith ActiveWorkbookWinTag = .ProtectStructure Or .ProtectWindowsEndWithShTag =FalseFor Each w1 In WorksheetsShTag = ShTag Or w1.ProtectContentsNext w1IfNot ShTag AndNot WinTag ThenMsgBox MSGNOPWORDS1, vbInformation, HEADERExitSubEndIfMsgBox MSGTAKETIME, vbInformation, HEADERIfNot WinTag ThenMsgBox MSGNOPWORDS2, vbInformation, HEADERElseOn ErrorResumeNextDoFor i =65To66:For j =65To66:For k =65To66For l =65To66:For m =65To66:For i1 =65To66For i2 =65To66:For i3 =65To66:For i4 =65To66For i5 =65To66:For i6 =65To66:For n =32To126With 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 =FalseAnd .ProtectWindows =FalseThenPWord1 =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, HEADERExitDoEndIfEndWithNext:Next:Next:Next:Next:NextNext:Next:Next:Next:Next:NextLoopUntilTrueOn ErrorGoTo0EndIfIf WinTag AndNot ShTag ThenMsgBox MSGONLYONE, vbInformation, HEADERExitSubEndIfOn ErrorResumeNextFor Each w1 In Worksheets'尝试用PWord1清除w1.Unprotect PWord1Next w1On ErrorGoTo0ShTag =FalseFor Each w1 In Worksheets'检查所有清除ShTag是否触发为1ShTag = ShTag Or w1.ProtectContentsNext w1If ShTag ThenFor Each w1 In WorksheetsWith w1If .ProtectContents ThenOn ErrorResumeNextDoFor i =65To66:For j =65To66:For k =65To66For l =65To66:For m =65To66:For i1 =65To66For i2 =65To66:For i3 =65To66:For i4 =65To66For i5 =65To66:For i6 =65To66:For n =32To126.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)IfNot .ProtectContents ThenPWord1 =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'尝试在其他表格上找到PasswordFor Each w2 In Worksheetsw2.Unprotect PWord1Next w2ExitDoEndIfNext:Next:Next:Next:Next:NextNext:Next:Next:Next:Next:NextLoopUntilTrueOn ErrorGoTo0EndIfEndWithNext w1EndIfMsgBox ALLCLEAR & AUTHORS & VERSION & REPBACK, vbInformation, HEADEREndSub
摘要:FTP连接时,提示错误信息:500 OOPS: vsftpd: both local and anonymous access disabled! FTP连接时,提示错误信息: 500 OOPS: vsftpd: both local and anonymous access disabled! 原因分析,vsftpd的配…
云原生数据仓库AnalyticDB基础版来了!
点我看直播回放惊喜优惠!体验10元3个月
发布会PPT资料放送(点击可直接查看哦)
ADB基础版:云原生MySQL敏捷数仓ADB for MySQL 基础版技术解密基于ADB for MySQL基础版构建实时数…
本文是基于本人对MaxCompute产品的学习进度,再结合开发者社区里面的一些问题,进而整理成文。希望对大家有所帮助。
问题一、在 MaxCompute SQL执行过程中,报错Table xx has n columns, but query has m columns如何处理ÿ…