Solved

Copy Multiple Columns from one sheet to another with different headers

Posted on 2014-04-10
9
151 Views
Last Modified: 2014-04-14
Hi,

I have some VBA that copies one sheet from one workbook to another. Now that I have the data in the same workbook. I have searched, but have not been able to find a solution specific to what I need. I would like to copy specific columns from Store Schedule tab to the RC Schedule tab however the columns are not the same and the column names on Store Schedule tab can be in row 2 or 3 or both.  Example of some of the columns that I need to copy (maintaining the column header in the RC Schedule tab).  

From Store Schedule to RC Schedule Column
                  
1. Column A to A
2. Column C to B
3. Column D to D
4. Column E to F
5. Column HG to J

Attaching a sample of the file as well
International-Store-Schedule-Tem.xls
0
Comment
Question by:jmac001
  • 5
  • 4
9 Comments
 
LVL 45

Expert Comment

by:aikimark
ID: 39993225
are you sure you want C to B?  There is already a StoreNumber column on RC.
0
 

Author Comment

by:jmac001
ID: 39993936
Yes, the store number in the RC tab is different than the store number in the Store Schedule tab.
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39994679
See if this works for you.
Option Explicit

Public Sub Q_28409476()
    Dim wksFrom As Worksheet
    Dim wksTo As Worksheet
    Dim rngFrom As Range
'    Dim rngTo As Range
    Set wksFrom = Worksheets("Store Schedule")
    Set wksTo = Worksheets("RC Schedule")
    Set rngFrom = wksFrom.Range(wksFrom.Range("A5"), wksFrom.Range("A5").End(xlDown))
    rngFrom.Copy wksTo.Range("A2")
    Set rngFrom = wksFrom.Range(wksFrom.Range("C5"), wksFrom.Range("C5").End(xlDown))
    rngFrom.Copy wksTo.Range("B2")
    Set rngFrom = wksFrom.Range(wksFrom.Range("D5"), wksFrom.Range("D5").End(xlDown))
    rngFrom.Copy wksTo.Range("D2")
    Set rngFrom = wksFrom.Range(wksFrom.Range("E5"), wksFrom.Range("E5").End(xlDown))
    rngFrom.Copy wksTo.Range("F2")
    Set rngFrom = wksFrom.Range(wksFrom.Range("HG5"), wksFrom.Range("HG5").End(xlDown))
    rngFrom.Copy wksTo.Range("J2")
End Sub

Open in new window

0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 

Author Comment

by:jmac001
ID: 39995265
Question, I have fields that will not have data, how do I account for that in the VBA.  I placed the code in my working file  and where ever there was a break in the data is where the data stopped for that column.
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39995301
That's generally done by using the lastcell special reference or invoking a Find method to get the last cell in a column (or row).  Do you know how to do that?
0
 

Author Comment

by:jmac001
ID: 39998783
No, I don't
0
 
LVL 45

Accepted Solution

by:
aikimark earned 500 total points
ID: 39999218
Test this version.
Option Explicit


Public Sub Q_28409476()
    Dim wksFrom As Worksheet
    Dim wksTo As Worksheet
    Dim rngFrom As Range
    Dim lngLastRow As Long
    
    Set wksFrom = Worksheets("Store Schedule")
    lngLastRow = wksFrom.Cells.SpecialCells(xlCellTypeLastCell).Row
    Set wksTo = Worksheets("RC Schedule")
    Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 1), wksFrom.wksFrom.Cells(lngLastRow, 1))
    rngFrom.Copy wksTo.Range("A2")
    Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 3), wksFrom.wksFrom.Cells(lngLastRow, 3))
    rngFrom.Copy wksTo.Range("B2")
    Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 4), wksFrom.wksFrom.Cells(lngLastRow, 4))
    rngFrom.Copy wksTo.Range("D2")
    Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 5), wksFrom.wksFrom.Cells(lngLastRow, 5))
    rngFrom.Copy wksTo.Range("F2")
    Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 215), wksFrom.wksFrom.Cells(215, lngLastRow))
    rngFrom.Copy wksTo.Range("J2")
End Sub

Open in new window

0
 

Author Comment

by:jmac001
ID: 39999842
Get errror 1004  (application - defined or or object-defined error) on:

Line 21 -  Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 215), wksFrom.Cells(215 lngLastRow))
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39999930
That should be:
Set rngFrom = wksFrom.Range(wksFrom.Cells(5, 215), wksFrom.Cells(lngLastRow, 215))

Open in new window

0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

INDEX and MATCH can be used to great effect to replace HLOOKUP and VLOOKUP as it does not have the limitation of needing the data to be sorted so that the reference value is in the first column or row. It also has the ability to perform a bi-directi…
This article descibes how to create a connection between Excel and SAP and how to move data from Excel to SAP or the other way around.
This Micro Tutorial demonstrate the bugs in Microsoft Excel for Mac with Pivot Charts.
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

830 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question