'For .. Next' Problem

ot070707

New Member
Joined
Nov 12, 2008
Messages
6
Hi,
My code loops through worksheets from 12 onwards and saves each as a separate file.
I've used a For...Next loop to do this - this is the same one I've used in other macros and it works fine.
However on this occasion, it won't stop at the final sheet; it tries to do another loop and therefore crashes.
There must be something obvious - I just can't see it!
I've copied all the code below in case something earlier on is breaking it.
Thanks for any help.
Regards.
Mark

Sub SaveCCFiles()
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim Sourcewb As Workbook
Dim Destwb As Workbook
Dim FilePath As String
Dim FileName As String
Dim CCLookup As String
Dim Period As String
Dim FolderCheck As String
Dim Location As String
Dim Response2 As String
Dim CreateFolder
Dim CheckCell As Range
Dim StartCheck As Range
Dim EndCheck As Range
Dim CheckMessage As String
Dim z As Integer
'======================================================================================
'Checks for #N/As again
Set StartCheck = Worksheets("data").Range("a4")
Set EndCheck = Worksheets("data").Range("d65534").End(xlUp)

For Each CheckCell In Range(StartCheck, EndCheck)
If WorksheetFunction.IsNA(CheckCell) Then
CheckMessage = "Cell " & CheckCell.Address & " shows an error. Please correct."
MsgBox CheckMessage
Range(CheckCell.Address).Activate
Exit Sub
If CheckCell.Text = "#N/A" Then
CheckMessage = "Cell " & CheckCell.Address & " shows an error. Please correct."
MsgBox CheckMessage
Range(CheckCell.Address).Activate
Exit Sub
End If
End If

Next
'============================================================================================
With Application
.ScreenUpdating = True
.EnableEvents = False
End With
'Ask where to save the files
'================================================================================================
Do
FilePath = InputBox("Where do you want to save the files? Last character must be '\'!", "File Location...", "c:\users\mark\Files\")
If Right(FilePath, 1) <> "\" Then MsgBox "You haven't included the '\' at the end!"
Loop Until Right(FilePath, 1) = "\"

Response2 = MsgBox("The new files will now be created in " & FilePath _
& vbCrLf & "Click 'Cancel' if you do not wish to proceed.", vbOKCancel, "Information ...")
If Response2 = vbCancel Then Exit Sub

If Dir(FilePath, vbDirectory) = "" Then CreateFolder = MsgBox("The folder does not exist; do you wish to create it?", vbYesNo)

If CreateFolder = vbYes Then
MkDir FilePath
Else
MsgBox "The action was terminated." _
& vbCrLf & "" _
& vbCrLf & "The file was NOT created."

End If
'Go through all sheets from Sheet 12 and save - THIS IS WHERE IT GOES WRONG!
'=========================================================================
For z = 12 To Sheets.Count
Sheets(z).Select
Set Sourcewb = ActiveWorkbook
ActiveSheet.Copy
Set Destwb = ActiveWorkbook

FileName = ActiveSheet.name & " - From " & Sourcewb.name & " " & Format(Now, "dd-mmm-yy h-mm-ss")
With Destwb
.SaveAs FilePath & FileName & ".xls": FileFormatNum = -4143
.Close SaveChanges:=False
End With

Next
'Ask whether or not to delete the sheets in source file
'=====================================================
Range("A1").Select
Dim Quest As String
Dim Ans
Quest = InputBox("CC Files have been created. Do you want to delete the original worksheets now?", "Delete worksheets?", vbYes)
Select Case Ans
Case vbNo
Exit Sub
Case vbYes
For Each wks In Worksheets
If (wks.name <> "Data" And wks.name <> "Summary" And wks.name <> "Instructions" And _
wks.name <> "MI" And wks.name <> "Sheet4" And wks.name <> "Sheet5" And wks.name <> "Sheet6" And _
wks.name <> "Data Orig" And wks.name <> "SGL" And wks.name <> "Grade" And wks.name <> "Rates") Then wks.Delete
Next wks
End Select
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
End Sub
 

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.
Do you have any hidden sheets in your workbook?

Thanks Richard.
I've just tried using worksheets.count instead of sheets.count and that works.

sheets.count returns 14, worksheets.count returns 13 as I wanted. Not sure what extra sheet sheets.count is picking up.

Regards,

Mark
 
Upvote 0
Sheets.Count will include any charts you have in your workbook, whereas Worksheets.Count only counts actual worksheets.

Does that make sense?
 
Upvote 0
Yes, I did too - I didn't know that until you posted your question and I had to check for myself! :)
 
Upvote 0

Forum statistics

Threads
1,224,587
Messages
6,179,740
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