0
이 코드는 (Splitting worksheet into multiple workbooks)이 코드를 사용하고 있으며 간단한 데이터베이스를 사용하여 3 열에서 필터링 할 때 코드가 작동하는지 궁금합니다. 그러나 데이터베이스가 있습니다. 필터로 사용할 열 (별칭 )이 35 열 또는 "AI"에 있고이 경우 코드가 작동하지 않습니다. 따라서이 코드는 필터링 된 열의 값에 따라 통합 문서를 만들지 만 데이터 자체는 필터링되지 않으므로이 경우 세 개의 동일한 파일이 만들어집니다. 어떤 제안? 사용 된 코드입니다.Excel 워크 시트의 데이터를 열 값 기반의 여러 통합 문서로 분할
Sub CreateBatchWorkbooks()
On Error Resume Next
Application.DisplayAlerts = False
With ThisWorkbook.Sheets("CalcData") 'Replace the sheet name with the raw data sheet name
Set Newsheet = ThisWorkbook.Sheets("cal")
If Newsheet Is Nothing Then
Worksheets.Add.Name = "cal"
Else
ThisWorkbook.Sheets("cal").Delete
Worksheets.Add.Name = "cal"
End If
FilterField = WorksheetFunction.Match("BatchNumber()", ThisWorkbook.Sheets("CalcData").Range("1:1"), 0)
.Columns(FilterField).Copy
With ThisWorkbook.Sheets("cal")
.Range("a1").PasteSpecial (xlPasteAll)
.Columns("a").RemoveDuplicates Columns:=1, Header:=xlYes
End With
For Each cell In ThisWorkbook.Sheets("cal").Columns("a").Cells
i = i + 1
If i <> 1 And cell.Value <> "" Then
.AutoFilterMode = False
.Rows(1).AutoFilter field:=FilterField, Criteria1:=cell.Value
Set new_book = Workbooks.Add
.UsedRange.Copy
new_book.Sheets(1).Range("a1").PasteSpecial (xlPasteAll)
new_book.SaveAs Filename:=ThisWorkbook.Path & "\" & cell.Value & ".xlsx"
new_book.Sheets(1).UsedRange.Columns.AutoFit
new_book.Save
new_book.Close
End If
Next cell
ThisWorkbook.Sheets("cal").Delete
End With
End Sub
미리 감사드립니다.
이 오류에'없애를 사용하여 누군가를 위해 도움이 https://stackoverflow.com/documentation/입니다 vba/3211/오류 처리/11022/resume-keyword)). 이 줄로 인해 코드에서 발생하는 모든 오류는 완전히 무시됩니다. 받은 오류 메시지를 다시보고하십시오 (포함 된 게시물을 편집하십시오). 그런 다음 오류 처리에 관한 해당 설명서 섹션의 나머지 부분을 읽으십시오. OERN을 사용하는 정당한 이유가 거의 없습니다. – FreeMan
또한 한 열 범위에서 # 35 필드를 필터링하려고합니다. 링크 된 이전 게시물은 댓글에이 수정 사항을 표시합니다. –
방금 코드를 업데이트했습니다. 아직도 아무 것도 해결되고 있지 않습니다. 어떤 제안? – dmalvareg