VBA Copy Column "X"

Diogenes

New Member
Joined
Apr 2, 2014
Messages
34
Hi there,

I am having a bit of a brain freeze and was hoping that someone may be able to help me.

I am trying to write a VBA script that finds column "X" copies it across to column "X+1" and then pastes column "X" as values.

The formula that I have in a helper cell for determining column X is:

=IF(P5='Global Inputs'!$H$16,COLUMN(),"")

It would be great if someone could shed some light on the best way to make Q and P in the example below variable:

Code:
Sub Roll()'
' Roll column
'
    Selection.Copy
    Columns("Q:Q").Select
    ActiveSheet.Paste
    Columns("P:P").Select
    Application.CutCopyMode = False
    Selection.Copy
    Selection.PasteSpecial
End Sub

It seems as though it should be pretty straightforward to write a piece of code that says find column 16 copy it across to column 17 and then paste the original column 16 as values but for the life of me I can't work it out today!

Any help would be very much appreciated.


Thanks,
 

Excel Facts

Format cells as date
Select range and press Ctrl+Shift+3 to format cells as date. (Shift 3 is the # sign which sort of looks like a small calendar).
Depends, do you want to keep the cell references of any formulas that copy over or do you want it to increment? If the latter then this would work

Code:
    Columns("P:P").Copy Destination:=Columns("Q:Q")
    Columns("P:P").Copy
    Columns("P:P").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

but if the former then you would be better inserting a column in front of P then copying Q to P as values like so:

Code:
    Columns("P:P").Insert
    Columns("Q:Q").Copy
    Columns("P:P").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False


Now fortunately Excel is smart enough that you don't have to use a column letter, so once you decide the answer to the above we can just sub in X
 
Upvote 0
Did not exactly understand your post but try this:
Code:
Sub Copy_Column()
Columns(16).Copy
Columns(17).PasteSpecial xlPasteValues
Application.CutCopyMode = False
End Sub
 
Upvote 0
Thanks everyone for your comments.

The data in column P (16) is currently actual data. This data comes from an input sheet.

The data in column O (15) is historic and this is hard coded values.

The data in column Q (17) is forecasted data. This comes a forecast sheet.

As time moves on a particular column (P in this case) goes from forecast to actual to historic.

When it is actual and forecast the cells are formulas referencing other areas of the workbook but when historic it just needs to be hard-coded values.

So there is a column of "actual" formulas that is copied and pasted along the worksheet and it is replacing the forecast formulas in each column as it moves a long and leaving hard coded values behind it.

Does that make any sense?

Sorry for the confusion!

:)
 
Upvote 0
If you want to paste values use: PasteSpecial xlPasteValues
If you want to paste formulas use: PasteSpecial
 
Upvote 0
Just to shed some more light on my thinking the formula in the helper cell:

=IF(P5='Global Inputs'!$H$16,COLUMN(),"")

Always returns the column number for the actual data so it will go: 10, 11, 12, 13, etc.

Hence I was thinking of using the answer to this formula in some kind of R1C1 set up where the rows are irrelevant but telling the code to find column X based on the answer to the formula.

Then copy it, paste it in X+1 and then hard code what was in X.

It seems straightforward in my head but maybe it isn't?
 
Upvote 0
Thanks,

Where I am tripping up is the R1C1 referencing based on the answer to a formula.

Is this even possible? i.e.

This formula

=IF(P5='Global Inputs'!$H$16,COLUMN(),"")

Tells me what C should be and I just want the VBA to go across C rows copy across to C+1 and then paste its own values back into C.
 
Upvote 0
So in my code you would use columns(Range("A1").Value) instead of Columns("P:P")

Change Range("A1").Text to the cell where your helper column gives you the number

Columns("Q:Q") would obviously be changed to the same +1
 
Upvote 0
I'm making a mess of this and this is what i currently have and I am getting a syntax error.

Code:
Sub Roll()'


    Active.Sheet
    Range("B10").Value = _
    Columns(Range("B10")).Copy Destination:=Columns(Range("B10" + 1))
    Columns(Range("B10")).Copy
    Columns("B10").PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False


End Sub

My reference formula is currently in cell B10.

Thanks for your help
 
Upvote 0
Range("B10").Value gives you the result of your formula, it will be a number, use it anywhere you like as shown below.

Code:
Sub Roll()
    Columns(Range("B10").Value).Copy Destination:=Columns(Range("B10").Value + 1)
    Columns(Range("B10").Value).Copy
    Columns(Range("B10").Value).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
End Sub
 
Upvote 0

Forum statistics

Threads
1,223,237
Messages
6,170,928
Members
452,366
Latest member
TePunaBloke

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