Transfer data for one workbook to another automatically - vba

Jose_L_Perez

New Member
Joined
Apr 27, 2018
Messages
1
Need help... I have 2 workbooks One used internally for analyzing costing/pricing data (COSTING FILE TEMPLATE - NEW) and another workbook that is sent out to vendors for pricing/costing (VENDOR PRICING TEMPLATE). We have over 300 vendors that submit pricing that we have to transfer to our internal costing file to analyze.

What I need is a VBA code that would allow me pick a saved "VENDOR PRICING FILE" and transfer only the rows of data that have a cost to the internal "COSTING FILE" and sort the data by the item# on column A to keep like items togther.

Can not attach files at this time.

Please let me know if something like this is possible.
 

Excel Facts

Can a formula spear through sheets?
Use =SUM(January:December!E7) to sum E7 on all of the sheets from January through December
Need help... I have 2 workbooks One used internally for analyzing costing/pricing data (COSTING FILE TEMPLATE - NEW) and another workbook that is sent out to vendors for pricing/costing (VENDOR PRICING TEMPLATE). We have over 300 vendors that submit pricing that we have to transfer to our internal costing file to analyze.

What I need is a VBA code that would allow me pick a saved "VENDOR PRICING FILE" and transfer only the rows of data that have a cost to the internal "COSTING FILE" and sort the data by the item# on column A to keep like items togther.

Can not attach files at this time.

Please let me know if something like this is possible.

Hi,

It is indeed possible. My approach would be to open "vendor pricing file" when I open "costing file" (https://www.excel-easy.com/vba/events.html)
Code:
[LEFT][COLOR=#00a0c8][FONT='inherit']Sub Open_ExistingWorkbook()

    Workbooks.Open "C:\WorkbookName.xls"

    'OR

    'Workbooks.Open Filename:="C:\WorkbookName1.xls"

End Sub[/FONT][/COLOR]
[/LEFT]

To select the appropriate line, I would rather have a pivot table on a hidden sheet that has exactly the lines that I need, at the right format that I would copy-paste as values.
You can also copy paste each line based on a condition; so something like
Code:
Dim dCell as Range
For each dCell in Range("A2:A999")
If dcell.value="Ok" then
dcell.entirerow.copy
...
'CostingFile.activesheet.range("A1").end(xldown).offset(1,0).select
Activesheet.paste
End if
Next dcell
The issue with the method is it goes cell by cell to check the value, so can take quite a while.
Another option is .autofilter command, so you filter on a value
An easy way to properly copy-paste from one workbook to another and autofilter if you are not familiar is to record a macro and adapt it to the ranges that you need
 
Last edited:
Upvote 0

Forum statistics

Threads
1,223,893
Messages
6,175,244
Members
452,622
Latest member
Laura_PinksBTHFT

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