Я нашел этот код пару лет назад, и он работал потрясающе! Для этого он берет книгу Excel, разделяет все листы, а затем сохраняет каждый лист как свою собственную книгу.
Я пытался повторно использовать его, но на этот раз это не удалось.
Я кое-что копал, и причина его неудачи заключалась в том, что в новых рабочих книгах были отправлены скрытые листы. Вот код:
Sub SplitWorkbook()
'Updateby20140612
Dim FileExtStr As String
Dim FileFormatNum As Long
Dim xWs As Worksheet
Dim xWb As Workbook
Dim FolderName As String
Application.ScreenUpdating = False
Set xWb = Application.ThisWorkbook
DateString = Format(Now, "yyyy-mm-dd hh-mm-ss")
FolderName = xWb.Path & "\" & xWb.Name & " " & DateString
MkDir FolderName
For Each xWs In xWb.Worksheets
xWs.Copy
If Val(Application.Version) < 12 Then
FileExtStr = ".xls": FileFormatNum = -4143
Else
Select Case xWb.FileFormat
Case 51:
FileExtStr = ".xlsx": FileFormatNum = 51
Case 52:
If Application.ActiveWorkbook.HasVBProject Then
FileExtStr = ".xlsm": FileFormatNum = 52
Else
FileExtStr = ".xlsx": FileFormatNum = 51
End If
Case 56:
FileExtStr = ".xls": FileFormatNum = 56
Case Else:
FileExtStr = ".xlsb": FileFormatNum = 50
End Select
End If
xFile = FolderName & "\" & Application.ActiveWorkbook.Sheets(1).Name & FileExtStr
Application.ActiveWorkbook.SaveAs xFile, FileFormat:=FileFormatNum
Application.ActiveWorkbook.Close False
Next
MsgBox "You can find the files in " & FolderName
Application.ScreenUpdating = True
End Sub
Так что, если кто-то работал над книгой и спрятал листы, VBA потерпит неудачу. Если кто-нибудь знает, как работать с VBA, я был бы очень признателен за помощь.
В настоящее время VBA сохранит новую книгу в качестве имени листа, но было бы идеально, если бы я мог получить код для добавления старой книги "XXX" перед новым именем "XXX_new name"
Любая помощь очень ценится.