Transfer some modules from one workbook to another one

Doflamingo

Board Regular
Joined
Apr 16, 2019
Messages
238
Hi all,

I would like to transfer some moduls from a opened workbook to another one

Here is the code to create a new workbook ‘’workbook2’’ from an active worksheet of an other workbook ‘’workbook 1’’

Does someone know how to transfer the ‘’modul1’’ and the ‘’modul2’’ from the workbook1 to the workbook2

I found this on the forum
Code:
Public Sub CopyModule()    Const strModName As String = "C:\TempMod.BAS"        ActiveWorkbook.VBProject.VBComponents("MyModule").Export fielname:=strModName    Workbooks(2).VBProject.VBComponents.Import Filename:=strmodnamme    Kill strModNameEnd Sub
[h=2]From that thread Copy a code module from one workbook to another[/h]

but I tried to adapt it with my code and that does not work -lines of code in red-

Code:
Sub sb_Copy_Save_ActiveSheet_As_Workbook()
  Dim wname As String, wfolder1 As String, wfolder2 As String
  wname = ActiveSheet.Name
  wfolder1 = "C:\Users\AtivBook9\Downloads\Reims\"
 
  If Right(wfolder1, 1) <> "\" Then wfolder1 = wfolder1 & "\"
  If Dir(wfolder1, vbDirectory) = "" Then
    MsgBox "The folder does not exist! " & wfolder1, vbCritical
    Exit Sub
  End If
  wfolder2 = wfolder1 & wname & "\"
  If Dir(wfolder2, vbDirectory) = "" Then
    MkDir wfolder2
  End If
 
Range("E5").Value = wfolder2
 
  ActiveSheet.Copy
  ActiveWorkbook.SaveAs wfolder2 & wname & ".xlsm", FileFormat:=xlOpenXMLWorkbookMacroEnabled
 
 
  [COLOR=#ff0000]Const strModName As String = wfolder2 & wname & ".xlsm"
   
    ActiveWorkbook.VBProject.VBComponents("Module3").Export fielname:=strModName
    Workbooks(2).VBProject.VBComponents.Import FileName:=strmodnamme
    Kill strModName[/COLOR]
 
End Sub

Any idea ?
 

Excel Facts

What is the fastest way to copy a formula?
If A2:A50000 contain data. Enter a formula in B2. Select B2. Double-click the Fill Handle and Excel will shoot the formula down to B50000.
The const line won't compile, because constants can be built from sub strings change that to

Code:
Dim strModName As String
strModName = wfolder2 & wname & ".xlsm"
The next issue that I see is that the component that you are exporting comes from the ActiveWorkbook. This comes right after the ActiveSheet.Copy so the ActiveWorkbook is the new workbook that has no modules.
I also notice that the file name you chose for your exported module is the same as the name of the newly saved workbook. The OS won't like two files with the same name in the same place.

I'd try something like
Code:
Dim sourceBook as Worbook, newBook as workboook
Dim strModName As String 

strModName = wfolder2 & wname 
Set sourceBook = ActiveWorkbook

ActiveSheet.Copy
ActiveWorkbook.SaveAs wfolder2 & wname & ".xlsm", FileFormat:=xlOpenXMLWorkbookMacroEnabled

Set newBook = ActiveWorkbook
 
sourceBook.VBProject.VBComponents("Module3").Export fielname:= strModName

newBook.VBProject.VBComponents.Import FileName:=strmodnamme
 
Upvote 0

Forum statistics

Threads
1,225,739
Messages
6,186,738
Members
453,369
Latest member
juliewar

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top