ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1260|回复: 11

[求助] 用“VBA宏”删除指定“VBA宏”

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-8-9 07:57 | 显示全部楼层 |阅读模式
本帖最后由 wowo000 于 2023-8-9 07:58 编辑

各位老师:早上好!请教俺要用一个sub过程来删除另外一个或者几个sub过程,如何写VBA代码?恳请赐教,谢谢!!!

                比如:“模块1”里面有两个过程,分别为“Sub 冬天()”和“Sub 夏季()”,咋写一段VBA代码删除他俩???
                此问题可以不模拟附件上传吧?

TA的精华主题

TA的得分主题

发表于 2023-8-9 08:06 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-8-9 08:07 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
应该可以不过没用过,我一般都是新增

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-8-9 08:07 | 显示全部楼层

您好!早上好!俺用VBA代码来实现,可否赐教?

TA的精华主题

TA的得分主题

发表于 2023-8-9 08:10 来自手机 | 显示全部楼层
要使用VBA代码删除指定的宏,你可以通过以下步骤实现:

1. 打开Visual Basic编辑器:在Excel中按下Alt + F11打开Visual Basic for Applications(VBA)编辑器。

2. 导航到“模块”窗口:在左侧项目资源管理器窗格中找到并展开该工作簿的"Microsoft Excel Objects"节点。然后双击其中一个具有名称类似于"ThisWorkbook"或者是包含所需宏的特定工作表名字 的对象来打开对应模块。

3. 编写删除宏的代码:在选定了相应模块之后,在右侧空白区域内编写如下代码:
```vba
Sub DeleteMacro()
    Application.VBE.ActiveVBProject.VBComponents.Remove _
        VBComponent:=Application.ThisWorkbook.VBProject.vbcomponents("Module_Name")
End Sub
```
请将 "Module_Name" 替换为您想要删除其内容和相关设置以及过程/函数等信息的 VBA 模块名称。
如果需要同时从其他类型文件(例如: ThisDocument, SheetX) 删除,请修改上述行 `ThisWorkbook` 与适当引用进行替换.

4. 运行子程序:点击运行按钮 (位于顶部菜单栏或按F5),这会执行刚才编写好的DeleteMacro() 子程序,并且会自动移除目标 VBA 宏。

重要提示:
- 在操作前最好备份一次文档,防止意外删除。
- 请确保您有足够的权限来修改VBA项目,否则可能会出现访问被拒绝的错误。

希望这个解释对你有所帮助!如果还有其他问题,请随时提问。

TA的精华主题

TA的得分主题

发表于 2023-8-9 08:11 来自手机 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
问AI呀         

TA的精华主题

TA的得分主题

发表于 2023-8-9 08:30 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助


  1. Sub DeleteProcedure()
  2.     Dim moduleName As String
  3.     Dim procedureName As String
  4.     Dim startLine As Long
  5.     Dim endLine As Long
  6.    
  7.     moduleName = "模块1" ' 替换为您要删除过程的模块名称
  8.     procedureName = "冬天" ' 替换为您要删除的过程名称
  9.    
  10.     Set codeModule = ThisWorkbook.VBProject.VBComponents(moduleName).codeModule
  11.    
  12.     startLine = codeModule.ProcStartLine(procedureName, vbext_pk_Proc)
  13.     endLine = codeModule.ProcCountLines(procedureName, vbext_pk_Proc)
  14.    
  15.     codeModule.DeleteLines startLine, endLine
  16.    
  17.     MsgBox "过程删除成功!", vbInformation
  18. End Sub
复制代码



来源于AI,注意excel必须勾选“信任VB工程访问
(1)EXCEL已设置:  
工具(T)-宏(M)-安全性(M)-可靠发行商(T)-勾选了“信任对于VB项目的访问(V)”

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-8-9 09:01 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-8-9 09:03 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
应该就是7楼那样

TA的精华主题

TA的得分主题

发表于 2023-8-9 09:04 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
3.删除过程aTest:  
Sub DelCodes()  
       With ThisWorkbook.VBProject.VBComponents("模块1").CodeModule
            .DeleteLines . ProcStartLine("aTest", 0), .ProcCountLines("aTest", 0)
       End With
End Sub
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-9-21 11:22 , Processed in 0.033182 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表