我正在VBA编辑器(可扩展性)中编程,并以编程方式创建一个新模块。创建新模块时没有任何问题。但是,当创建新模块时,它将在代码窗格中作为空白模块打开,这是事实。但是,我希望活动模块(运行创建新模块的代码的模块)在创建新模块后返回到代码窗格。我不知道这样做的命令是什么。这就是我到目前为止所尝试的。
Sub addNewStandardModule()
On Error Resume Next' Adds Extensibility Reference for programming in the VBE
ThisWorkbook.VBProject.References.AddFromGuid GUID:="{0002E157-0000-0000-C000-000000000046}", Major:=5, Minor:=3
On Error GoTo 0
Dim VBProj As VBIDE.VBProject
Dim VBComp As VBIDE.VBComponent
Dim CodeMod As VBIDE.CodeModule
Set VBProj = ActiveWorkbook.VBProject
Set VBComp = VBProj.VBComponents.Add(vbext_ct_StdModule)
VBComp.name = "Module6"
' This is my attempt to return the active module to the active codepane, but it doesn't work
With Application.VBE
If Not .ActiveCodePane Is Nothing Then
Set .ActiveVBProject = .ActiveCodePane.CodeModule.Parent.Collection.Parent
End If
End With
End Sub发布于 2017-05-16 02:39:59
我自己发现的。希望它对将来的任何人都有用。
Sub createNewCodeModuleAndReturnToThisOne()
Dim VBEProj As VBIDE.VBProject
Dim vbComp As VBIDE.VBComponent
Dim VBProj As VBIDE.VBProject
Set VBEProj = ActiveWorkbook.VBProject
Set vbComp = Application.VBE.ActiveVBProject.VBComponents.Add(vbext_ct_StdModule)
vbComp.name = "Module6"
VBEProj.VBComponents("Module5").Activate
End Subhttps://stackoverflow.com/questions/43939954
复制相似问题