VBA code to open workbook, select worksheet, save entire worksheet as CSV file

CLCoop

Board Regular
Joined
May 30, 2018
Messages
56
Trying to coding VBA in a workbook (Start), vbaproject excel objects: thisworkbook to run the code when it opens.

Want to open workbook that can vary in name (ie: SOF 180530) and then go to worksheet (BAA), select the entire BAA worksheet and save file as a different format CSV (ie: SOFData.CSV)
Once the new file is created to reopen the file and be on the only worksheet SOFData. Want to turn off the pop notifications and override existing files if any.

At this time this is the code I have but get a Run-Time error '9 and for some reason it takes this workbook (start) and makes another file called (SOFData), eek:

'this line works
Code:
Private Sub Workbook_Open()
MsgBox "Hello and Welcome to the FAD Update and Back up Process click OK to PROCEED"

Dim wkb as workbook
Dim sht as worksheet

Set wkb = workbooks.open ("K:\CLC\FAD\*SOF????*.xlsx")   'this line appears to work as the file is in the background 
Set sht = wkb.sheets ("BAA ").Copy                                    'the workbook is in the back ground but not on the right sheet
Thisworkbook =.Saveas filename:="[LEFT][COLOR=#222222][FONT=Verdana]K:\CLC\FAD\SOFData.csv", FileFormate:=x1CSVWindos   
   ActiveWindow.Close

Set wkb= Workbooks.Open("[LEFT][COLOR=#222222][FONT=Verdana]K:\CLC\FAD\SOFData.csv[/FONT][/COLOR]")
[/LEFT]

Dim wb as string
Dim sh as String
Dim Path as String
path = "[LEFT][COLOR=#222222][FONT=Verdana]K:\CLC\FAD\SOFData.csv[/FONT][/COLOR]"
[/LEFT]
wb="SOFData.csv"
sh="SOFData"
Sheets(sh).Active

End Sub

Thanks in advance
[/FONT][/COLOR][/LEFT]
 
Last edited by a moderator:

Excel Facts

Using Function Arguments with nested formulas
If writing INDEX in Func. Arguments, type MATCH(. Use the mouse to click inside MATCH in the formula bar. Dialog switches to MATCH.
Are you sure this is actually opening workbook?

As far as I'm aware when opening a workbook you need to explicitly state the path and filename.
Code:
Set wkb = workbooks.open ("K:\CLC\FAD\*SOF????*.xlsx")   'this line appears to work as the file is in the background
 
Upvote 0
You can use this kind of code when your not sure of the name or if someone is save a file with a date in it. This line isn't the issue it works great.
For example if you have a file that is updated each day/week/month/year for archiving but you only want to look at the most current this code will see several files like:
SOF 180518
SOF 180630
SOF 180730

Tell your code to find the file that starts with "*SOF1806??*.xlsx" and it will find the file that matches. Nice

Now if I can just figure out the other stuff. So the file opens just fine, but I can't get it to go to the right worksheet. without creating an error.
 
Upvote 0

Forum statistics

Threads
1,225,477
Messages
6,185,221
Members
453,283
Latest member
Shortm88

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