VBA Import cells from a closed workbook

Status
Not open for further replies.

Dan5977

Board Regular
Joined
Aug 7, 2008
Messages
111
Office Version
  1. 2010
Hi all,

I have spent hours searching through past threads to try and come up with a solution but I have failed and I'm not good at VBA. So your help would be greatly appreciated.

I am trying to import a range from a closed workbook into an open workbook.

This is what I have so far:

Code:
Sub vbaimport()
' Defines variables
Dim wb1 As Workbook, wb2 As Workbook

' Disable screen updating to reduce screen flicker
Application.ScreenUpdating = False

' Define which workbook is which
Set wb1 = ThisWorkbook
Set wb2 = Workbooks.Open("C:\Users\dan\Documents\Book1.xlsx")

' Copy range A1:A5 from Sheet1 of wb2
wb2.Sheets("Sheet1").Range("A1:A5").Copy
' Paste the copied data to range A1 of the VBAImport sheet in wb1
wb1.Sheets("VBAImport").Range("A1").Paste

' Close wb2
wb2.Close

' Re-enable screen updating
Application.ScreenUpdating = True

End Sub

I expected this to work but I am getting
Run-time error '438':
Object doesn't support this property or method

It is getting as far as opening the workbook and copying the relevant cells but then errors, so doesn't paste those cells into my current workbook.

Any ideas why it's failing?

Following that solution and to take this a stage further, rather than having a set file as wb2, I need to be able to browse to a different file each time. Preferably I would specify a folder in the code and then simply double click on the relevant file. The copied cells will always be the same range.

Can anyone help? Thanks in advance :)
 

Excel Facts

Square and cube roots
The =SQRT(25) is a square root. For a cube root, use =125^(1/3). For a fourth root, use =625^(1/4).
For your problem try:

Code:
wb1.Sheets("VBAImport").Range("A1:A5").Value2 = wb2.Sheets("Sheet1").Range("A1:A5").Value2

Instead of copy/paste
 
Upvote 0
That works perfectly - thanks so much!

Now if anyone could help me with part 2 of my issue that would be great :)

Following that solution and to take this a stage further, rather than having a set file as wb2, I need to be able to browse to a different file each time. Preferably I would specify a folder in the code and then simply double click on the relevant file. The copied cells will always be the same range.
 
Upvote 0
Remove your set WB2 line and try this:

Code:
 Chdir "C:\"
  FName = Application.GetOpenFilename
  If FName <> False Then
    Set WB2 = Workbooks.Open(FName)
  End If
Untested but it looks right
 
Last edited:
Upvote 0
That works. Absolutely fantastic. Thanks for your prompt and easy to understand assistance.

One other thing that would be nice to have but is by no means critical. Is there a way to stop it asking me if I want to save the changes when it closes wb2?
 
Upvote 0
That works. Absolutely fantastic. Thanks for your prompt and easy to understand assistance.

One other thing that would be nice to have but is by no means critical. Is there a way to stop it asking me if I want to save the changes when it closes wb2?

Never mind - This was easy and as such I shouldn't have asked.
I simply added
SaveChanges:=False
after wb2.close
 
Upvote 0
Hi,
This worked perfectly loved it!

I hope someone will answer this... I am looking to have wb1 dump the copied information at the bottom of a list but am having some issues getting that done.

I have tried to include an offset but it did not work. All I am looking to do is have this select column b and add what's copied to the next cell that is open. My header starts on B5 which is my constant and everything would be pasted below that point.

wb1.Sheets("VBAImport").Range("A1:A5").Value2 = wb2.Sheets("Sheet1").Range("A1:A5").Value2

Thanks a bunch,
Tim G
 
Upvote 0
@kansfan2001
Welcome to the MrExcel board!

Please take a few minutes to review the Forum Rules
#12 asks you not to post duplicate questions. Therefore I am closing this thread and you should continue only in the other one. In that thread you can provide a link back to this one if required.
 
Upvote 0
Status
Not open for further replies.

Forum statistics

Threads
1,225,626
Messages
6,186,087
Members
453,336
Latest member
Excelnoob223

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