value to next blank in range

orsm6

Well-known Member
Joined
Oct 3, 2012
Messages
515
Office Version
  1. 365
Platform
  1. Windows
Hi all - i found this code on this site and g
have been trying to manipulate it a little to do what i need. it works, but what i need it to do is put the value in the next blank cell in column A.
There is a grand total cell at the bottom of A and so it puts the data after that.

here is my modified code, but how do i get the values to go to the last cell in A but in the range of A2:A100?

Code:
Sub CopyRange()
    Application.ScreenUpdating = False
    Dim wkbDest As Workbook
    Dim wkbSource As Workbook
    Set wkbDest = ThisWorkbook
    Dim LastRow As Long
    Const strPath As String = "C:\Users\ETC1944\Desktop\dispo\"
    ChDir strPath
    strExtension = Dir("*.xls*")
    Do While strExtension <> ""
        Set wkbSource = Workbooks.Open(strPath & strExtension)
        With wkbSource
            LastRow = .Sheets("sheet1").Cells.Find("*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
            .Sheets("Sheet1").Range("a8:I20").Copy wkbDest.Sheets("2020 disposition tracker").Cells(.Count, "A1", Range("a100").End(xlUp).Offset(1, 0))
            .Close savechanges:=False
        End With
        strExtension = Dir
    Loop
    Application.ScreenUpdating = True
End Sub

thanks
 

Excel Facts

How to create a cell-sized chart?
Tiny charts, called Sparklines, were added to Excel 2010. Look for Sparklines on the Insert tab.
The line:
LastRow = .Sheets("sheet1").Cells.Find("*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
is not use, right? I don't see you use the LastRow value at all. It can be removed.

Line:
.Sheets("Sheet1").Range("a8:I20").Copy wkbDest.Sheets("2020 disposition tracker").Cells(.Count, "A1", Range("a100").End(xlUp).Offset(1, 0))
is you are copying Sheet1 range A8:I20 and you are trying to copy to next empty row in column A as I understood it.

If you want to go to last cell in range A2:A100, then it should be
wkbDest.Sheets("2020 disposition tracker").Cells(101, "A").End(xlUp).Offset(1, 0)

I use 101 since the last cell could be 100.

Try if this code works to your need. I have not tested it
VBA Code:
Sub CopyRange()
    Application.ScreenUpdating = False
    Dim wkbDest As Workbook
    Dim wkbSource As Workbook
    Set wkbDest = ThisWorkbook
    Const strPath As String = "C:\Users\ETC1944\Desktop\dispo\"
    ChDir strPath
    strExtension = Dir("*.xls*")
    Do While strExtension <> ""
        Set wkbSource = Workbooks.Open(strPath & strExtension)
        With wkbSource
            .Sheets("Sheet1").Range("a8:I20").Copy wkbDest.Sheets("2020 disposition tracker").Cells(101, "A").End(xlUp).Offset(1, 0)
            .Close savechanges:=False
        End With
        strExtension = Dir
    Loop
    Application.ScreenUpdating = True
End Sub
 
Upvote 0
Solution
The line:
LastRow = .Sheets("sheet1").Cells.Find("*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
is not use, right? I don't see you use the LastRow value at all. It can be removed.

Line:
.Sheets("Sheet1").Range("a8:I20").Copy wkbDest.Sheets("2020 disposition tracker").Cells(.Count, "A1", Range("a100").End(xlUp).Offset(1, 0))
is you are copying Sheet1 range A8:I20 and you are trying to copy to next empty row in column A as I understood it.

If you want to go to last cell in range A2:A100, then it should be
wkbDest.Sheets("2020 disposition tracker").Cells(101, "A").End(xlUp).Offset(1, 0)

I use 101 since the last cell could be 100.

Try if this code works to your need. I have not tested it
VBA Code:
Sub CopyRange()
    Application.ScreenUpdating = False
    Dim wkbDest As Workbook
    Dim wkbSource As Workbook
    Set wkbDest = ThisWorkbook
    Const strPath As String = "C:\Users\ETC1944\Desktop\dispo\"
    ChDir strPath
    strExtension = Dir("*.xls*")
    Do While strExtension <> ""
        Set wkbSource = Workbooks.Open(strPath & strExtension)
        With wkbSource
            .Sheets("Sheet1").Range("a8:I20").Copy wkbDest.Sheets("2020 disposition tracker").Cells(101, "A").End(xlUp).Offset(1, 0)
            .Close savechanges:=False
        End With
        strExtension = Dir
    Loop
    Application.ScreenUpdating = True
End Sub
that is perfect, thanks very much Zot
 
Upvote 0

Forum statistics

Threads
1,224,591
Messages
6,179,768
Members
452,940
Latest member
rootytrip

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