VBA精彩代码分享-1
今天下班前分享一下之前在网上搜到的两段好用的VBA代码,貌似都来自国外,觉得挺好,模仿不来。
第一段的功能是修改VBA控件中的文本框控件,使其右键可以选择粘贴、复制、剪切等:
- Option Explicit
- ' Required API declarations
- Private Declare Function CreatePopupMenu Lib "user32" () As Long
- Private Declare Function InsertMenuItem Lib "user32" Alias "InsertMenuItemA" (ByVal hMenu As Long, ByVal un As Long, ByVal bool As Boolean, ByRef lpcMenuItemInfo As MENUITEMINFO) As Long
- Private Declare Function TrackPopupMenu Lib "user32" (ByVal hMenu As Long, ByVal wFlags As Long, ByVal X As Long, ByVal Y As Long, ByVal nReserved As Long, ByVal hwnd As Long, lprc As RECT) As Long
- Private Declare Function DestroyMenu Lib "user32" (ByVal hMenu As Long) As Long
- Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
- Private Declare Function GetCursorPos Lib "user32" (lpPoint As POINTAPI) As Long
- ' Type required by TrackPopupMenu although this is ignored !!
- Private Type RECT
- Left As Long
- Top As Long
- Right As Long
- Bottom As Long
- End Type
- ' Type required by InsertMenuItem
- Private Type MENUITEMINFO
- cbSize As Long
- fMask As Long
- fType As Long
- fState As Long
- wID As Long
- hSubMenu As Long
- hbmpChecked As Long
- hbmpUnchecked As Long
- dwItemData As Long
- dwTypeData As String
- cch As Long
- End Type
- ' Type required by GetCursorPos
- Private Type POINTAPI
- X As Long
- Y As Long
- End Type
- ' Constants required by TrackPopupMenu
- Private Const TPM_LEFTALIGN = &H0&
- Private Const TPM_TOPALIGN = &H0
- Private Const TPM_RETURNCMD = &H100
- Private Const TPM_RIGHTBUTTON = &H2&
- ' Constants required by MENUITEMINFO type
- Private Const MIIM_STATE = &H1
- Private Const MIIM_ID = &H2
- Private Const MIIM_TYPE = &H10
- Private Const MFT_STRING = &H0
- Private Const MFT_SEPARATOR = &H800
- Private Const MFS_DEFAULT = &H1000
- Private Const MFS_ENABLED = &H0
- Private Const MFS_GRAYED = &H1
- ' Contants defined by me for menu item IDs
- Private Const ID_Cut =
- Private Const ID_Copy =
- Private Const ID_Paste =
- Private Const ID_Delete =
- Private Const ID_SelectAll =
- ' Variables declared at module level
- Private FormCaption As String
- Private Cut_Enabled As Long
- Private Copy_Enabled As Long
- Private Paste_Enabled As Long
- Private Delete_Enabled As Long
- Private SelectAll_Enabled As Long
- Public Sub ShowPopup(oForm As UserForm, strCaption As String, X As Single, Y As Single)
- Dim oControl As MSForms.TextBox
- Static click_flag As Long
- ' The following is required because the MouseDown event
- ' fires twice when right-clicked !!
- click_flag = click_flag +
- ' Do nothing on first firing of MouseDown event
- If (click_flag Mod <> ) Then Exit Sub
- ' Set object reference to the textboxthat was clicked
- Set oControl = oForm.ActiveControl
- ' If click is outside the textbox, do nothing
- If X > oControl.Width Or Y > oControl.Height Or X < Or Y < Then Exit Sub
- ' Retrieve caption of UserForm for use in FindWindow API
- FormCaption = strCaption
- ' Call routine that sets menu items as enabled/disabled
- Call EnableMenuItems(oForm)
- ' Call function that shows the menu and return the ID
- ' of the selected menu item. Subsequent action depends
- ' on the returned ID.
- Select Case GetSelection()
- Case ID_Cut
- oControl.Cut
- Case ID_Copy
- oControl.Copy
- Case ID_Paste
- oControl.Paste
- Case ID_Delete
- oControl.SelText = ""
- Case ID_SelectAll
- With oControl
- .SelStart =
- .SelLength = Len(oControl.Text)
- End With
- End Select
- End Sub
- Private Sub EnableMenuItems(oForm As UserForm)
- Dim oControl As MSForms.TextBox
- Dim oData As DataObject
- Dim testClipBoard As String
- On Error Resume Next
- ' Set object variable to clicked textbox
- Set oControl = oForm.ActiveControl
- ' Create DataObject to access the clipboard
- Set oData = New DataObject
- ' Enable Cut/Copy/Delete menu items if text selected
- ' in textbox
- If oControl.SelLength > Then
- Cut_Enabled = MFS_ENABLED
- Copy_Enabled = MFS_ENABLED
- Delete_Enabled = MFS_ENABLED
- Else
- Cut_Enabled = MFS_GRAYED
- Copy_Enabled = MFS_GRAYED
- Delete_Enabled = MFS_GRAYED
- End If
- ' Enable SelectAll menu item if there is any text in textbox
- If Len(oControl.Text) > Then
- SelectAll_Enabled = MFS_ENABLED
- Else
- SelectAll_Enabled = MFS_GRAYED
- End If
- ' Get data from clipbaord
- oData.GetFromClipboard
- ' Following line generates an error if there
- ' is no text in clipboard
- testClipBoard = oData.GetText
- ' If NO error (ie there is text in clipboard) then
- ' enable Paste menu item. Otherwise, diable it.
- If Err.Number = Then
- Paste_Enabled = MFS_ENABLED
- Else
- Paste_Enabled = MFS_GRAYED
- End If
- ' Clear the error object
- Err.Clear
- ' Clean up object references
- Set oControl = Nothing
- Set oData = Nothing
- End Sub
- Private Function GetSelection() As Long
- Dim menu_hwnd As Long
- Dim form_hwnd As Long
- Dim oMenuItemInfo1 As MENUITEMINFO
- Dim oMenuItemInfo2 As MENUITEMINFO
- Dim oMenuItemInfo3 As MENUITEMINFO
- Dim oMenuItemInfo4 As MENUITEMINFO
- Dim oMenuItemInfo5 As MENUITEMINFO
- Dim oMenuItemInfo6 As MENUITEMINFO
- Dim oRect As RECT
- Dim oPointAPI As POINTAPI
- ' Find hwnd of UserForm - note different classname
- ' Word 97 vs Word2000
- #If VBA6 Then
- form_hwnd = FindWindow("ThunderDFrame", FormCaption)
- #Else
- form_hwnd = FindWindow("ThunderXFrame", FormCaption)
- #End If
- ' Get current cursor position
- ' Menu will be drawn at this location
- GetCursorPos oPointAPI
- ' Create new popup menu
- menu_hwnd = CreatePopupMenu
- ' Intitialize MenuItemInfo structures for the 6
- ' menu items to be added
- ' Cut
- With oMenuItemInfo1
- .cbSize = Len(oMenuItemInfo1)
- .fMask = MIIM_STATE Or MIIM_ID Or MIIM_TYPE
- .fType = MFT_STRING
- .fState = Cut_Enabled
- .wID = ID_Cut
- .dwTypeData = "Cut"
- .cch = Len(.dwTypeData)
- End With
- ' Copy
- With oMenuItemInfo2
- .cbSize = Len(oMenuItemInfo2)
- .fMask = MIIM_STATE Or MIIM_ID Or MIIM_TYPE
- .fType = MFT_STRING
- .fState = Copy_Enabled
- .wID = ID_Copy
- .dwTypeData = "Copy"
- .cch = Len(.dwTypeData)
- End With
- ' Paste
- With oMenuItemInfo3
- .cbSize = Len(oMenuItemInfo3)
- .fMask = MIIM_STATE Or MIIM_ID Or MIIM_TYPE
- .fType = MFT_STRING
- .fState = Paste_Enabled
- .wID = ID_Paste
- .dwTypeData = "Paste"
- .cch = Len(.dwTypeData)
- End With
- ' Separator
- With oMenuItemInfo4
- .cbSize = Len(oMenuItemInfo4)
- .fMask = MIIM_TYPE
- .fType = MFT_SEPARATOR
- End With
- ' Delete
- With oMenuItemInfo5
- .cbSize = Len(oMenuItemInfo5)
- .fMask = MIIM_STATE Or MIIM_ID Or MIIM_TYPE
- .fType = MFT_STRING
- .fState = Delete_Enabled
- .wID = ID_Delete
- .dwTypeData = "Delete"
- .cch = Len(.dwTypeData)
- End With
- ' SelectAll
- With oMenuItemInfo6
- .cbSize = Len(oMenuItemInfo6)
- .fMask = MIIM_STATE Or MIIM_ID Or MIIM_TYPE
- .fType = MFT_STRING
- .fState = SelectAll_Enabled
- .wID = ID_SelectAll
- .dwTypeData = "Select All"
- .cch = Len(.dwTypeData)
- End With
- ' Add the 6 menu items
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo1
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo2
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo3
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo4
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo5
- InsertMenuItem menu_hwnd, , True, oMenuItemInfo6
- ' Return the ID of the item selected by the user
- ' and set it the return value of the function
- GetSelection = TrackPopupMenu _
- (menu_hwnd, _
- TPM_LEFTALIGN Or TPM_TOPALIGN Or TPM_RETURNCMD Or TPM_RIGHTBUTTON, _
- oPointAPI.X, oPointAPI.Y, _
- , form_hwnd, oRect)
- ' Destroy the menu
- DestroyMenu menu_hwnd
- End Function
使用时复制进VBA工程中,再在窗体中新建一个文本框控件即可右击看到效果。
第二段的功能是破解EXCEL工作簿的所有密码,包括工作表保护密码,工作簿保护密码:
- 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 = To : For j = To : For k = To
- For l = To : For m = To : For i1 = To
- For i2 = To : For i3 = To : For i4 = To
- For i5 = To : For i6 = To : For n = To
- 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
- 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
- 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 = To : For j = To : For k = To
- For l = To : For m = To : For i1 = To
- For i2 = To : For i3 = To : For i4 = To
- For i5 = To : For i6 = To : For n = To
- .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
- End If
- End With
- Next w1
- End If
- MsgBox ALLCLEAR & AUTHORS & VERSION & REPBACK, vbInformation, HEADER
- End Sub
使用时复制进要破解的EXCEL的VBA工程中,F5运行即可,可能会等待较长时间。
如果需要破解VBA工程密码,需要将xlsm文件另存为xls文件,具体参考以下链接
https://blog.csdn.net/Q215046120/article/details/89964817
VBA精彩代码分享-1的更多相关文章
- VBA精彩代码分享-3
在开发VBA程序中,我们可能会需要用代码处理VBA工程,包括启用VBA工程访问,启用所有宏,动态插入代码,动态删除代码,动态添加引用和自动创建模块等等,本次的分享内容便以这些为主. 启用VBA工程访问 ...
- VBA精彩代码分享-4
VBA设置/取消工作簿共享是很常用的一个功能,那么如何用代码实现呢? 设置共享 Then MsgBox "文件没有保存" Exit Sub End If Application.D ...
- VBA精彩代码分享-2
VBA开发中经常需要提示消息框,如果不关闭程序就会暂时中断,这里分享下VBA如何实现消息框的自动关闭,总共有三种方法: 第一种方法 Public Declare Function MsgBoxTime ...
- JAVA基础代码分享--求圆面积
问题描述 用户输入圆的半径,计算并显示圆的面积 代码分享 /** * @author hpu-gs * 2015/11/25 */ public class Circle { public stati ...
- JAVA基础代码分享--DVD管理
问题描述 为某音像店开发一个迷你DVD管理器,最多可存6张DVD,实现碟片的管理. 管理器具备的功能主要有: 1.查看DVD信息. 菜单选择查看功能,展示DVD的信息. 2.新增DVD信息 选择新增功 ...
- JAVA基础代码分享--学生成绩管理
问题描述: 从键盘读入学生成绩,找出最高分,并输出学生成绩等级. 成绩>=最高分-10 等级为’A’ 成绩>=最高分-20 等级为’B’ 成绩>=最高分-30 等级为’C’ ...
- jQuery插件库代码分享 - 进阶者系列 - 学习者系列文章
这些天将原来在网上找的jQuery插件进行了下整理,特此将代码分享出来给大家. 见下图结构. 对目录结构进行了分类.这里是插件列表. 这里总共收集了20来个插件.还有下面未进行划分的. 下面是DEMO ...
- .net之工作流工程展示及代码分享(四)主控制类
现在应该讲主控制类了,为了不把系统弄得太复杂,所以就用一个类作为主要控制类(服务类),作为前端.后端.业务逻辑的控制类. WorkflowService类的类图如下: 该类的构造函数: public ...
- .net之工作流工程展示及代码分享(三)数据存储引擎
数据存储引擎是本项目里比较有特色的模块. 特色一,使用接口来对应不同的数据库.数据库可以是Oracle.Sqlserver.MogoDB.甚至是XML文件.采用接口进行对应: public inter ...
随机推荐
- [go]template使用
//index.html {{if gt .Age 18}} <p>hello, old man, {{.Name}}</p> {{else}} <p>hello, ...
- ColorDrawable
最简单的一种Drawable,当我们将ColorDrawable绘制到Canvas(画布)上的时候, 会使用一种固定的颜色来填充Paint,然后在画布上绘制出一片单色区域! 1).Java中定义Col ...
- wangEditor编辑器控件里textarea的id不要用content
头引用 <script type="text/javascript" src="js/jquery-1.10.2.min.js"></scri ...
- hdfs操作命令
文件操作命令:hdfs dfs -ls /hdfs dfs -mkdir /hdfs dfs -rm -rf /hdfshdfs dfs -duhdfs dfs -get /hdfs /localhd ...
- 在本地环境(mac)启用https
前段时间客户一个涉及地理定位功能的页面突然出问题不能正常使用,在修复的过程中发现定位的方法 getCurrentPosition 只能在 https 协议下才能成功调用,这导致我在本地不能调试,每次修 ...
- dp[2019.5.25]_2
1.对于长度相同的2个字符串A和B,其距离定义为相应位置字符距离之和.2个非空格字符的距离是它们的ASCII码之差的绝对值.空格与空格的距离为0,空格与其他字符的距离为一定值k. 在一般情况下,字符串 ...
- composer全量镜像使用方法
原文网址:https://pkg.phpcomposer.com/ Packagist 镜像使用方法 还没安装 Composer 吗?请往下看如何安装 Composer . 镜像用法 有两种方式启用本 ...
- JKD1.8新特性
1.Optional类 Optional是jdk1.8引入的类型,Optional是一个容器对象,它包括了我们需要的对象,使用isPresent方法判断所包 含对象是否为空,isPresent方法返回 ...
- 事理学神器PDCA
做事情都按PDCA循环来做,基本就是一个靠谱的人. 这个方法论其实也符合架构师的思维中的分治理论.把大事拆分成一件件小事,并把小事做好. Plan Do Check Action
- 教你用免费的hihttps开源WEB应用防火墙阻止暴力破解密码
教你用免费的hihttps开源WEB应用防火墙阻止暴力破解密码 很多企业都有自己的网站,需要用户登录后才能访问,但有大量的黑客攻击软件可以暴力破解网站密码,即使破解不了也非常恶心.有没有免费的解决办法 ...