VBA - Open workbook and import data to next empty row

ddoublev

New Member
Joined
May 22, 2017
Messages
37
Hi,

I am relatively new to the VBA world and would much appreciate some assistance with the following.

A project currently being worked on requires a macro to do the following:
  1. Open excel file from "Open file" dialog box
  2. Find data in specific ranges
  3. Copy data to next empty row of original worksheet
  4. Close workbook

I have developed the following:

Code:
Sub Import()
Dim OpenFileName As String
 Dim wb As Workbook
 'Select and Open workbook
 OpenFileName = Application.GetOpenFilename()
 If OpenFileName = "False" Then Exit Sub
 Set wb = Workbooks.Open(OpenFileName)
 'Get data EXAMPLE
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(1, 0).Value = wb.Sheets(3).Range("A2").Value
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(1, 1).Value = wb.Sheets(3).Range("B2").Value
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(1, 6).Value = wb.Sheets(3).Range("G2").Value
 MsgBox ("Done")
 wb.Close
End Sub

The actual code is much larger as there is a lot more data to import however I trimmed to show the core code.
The issue I am having with this is the initial run works on the first column however the code doesn't work properly for columns B & G

Is someone able to help with a code change?

Much appreciated

Dylan
 

Excel Facts

Get help while writing formula
Click the italics "fx" icon to the left of the formula bar to open the Functions Arguments dialog. Help is displayed for each argument.
See if this does what you want

Code:
Sub Import()
Dim OpenFileName As String
 Dim wb As Workbook
 'Select and Open workbook
 OpenFileName = Application.GetOpenFilename()
 If OpenFileName = "False" Then Exit Sub
 Set wb = Workbooks.Open(OpenFileName)
 'Get data EXAMPLE
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(1, 0).Value = wb.Sheets(3).Range("A2").Value
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(, 1).Value = wb.Sheets(3).Range("B2").Value
    ThisWorkbook.Sheets(1).Cells(Cells.Rows.Count, 1).End(xlUp).Offset(, 6).Value = wb.Sheets(3).Range("G2").Value
 MsgBox ("Done")
 wb.Close
End Sub
after you have made an entry into column A, If you offset the row for the other two it will offset from the entry just made, not the same row that was used for column A.
 
Upvote 0

Forum statistics

Threads
1,224,823
Messages
6,181,176
Members
453,021
Latest member
Justyna P

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