flyxlee
Sub SplitWorkSheet()
    Dim myRange As Variant
    Dim myArray
    Dim titleRange As Range
    Dim title As Variant
    Dim columnNum As Integer
    myRange = Application.InputBox(prompt:="请选择标题行:", Type:=8)
    myArray = WorksheetFunction.Transpose(myRange)
    Set titleRange = Application.InputBox(prompt:="请选择拆分的表头,必须是第一行,且为一个单元格,如:“组织”", Type:=8)
    title = titleRange.Value
    columnNum = titleRange.Column
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Dim i&, Myr&, arr, num&
    Dim d, k
    \'For i = Sheets.Count To 1 Step -1
        \'If Sheets(i).Name <> "Sheet1" Then
          
        \'End If
    \'Next i
    Set d = CreateObject("Scripting.Dictionary")
    Myr = Worksheets("Sheet1").UsedRange.Rows.Count
    arr = Worksheets("Sheet1").Range(Cells(2, columnNum), Cells(Myr, columnNum))
    For i = 1 To UBound(arr)
        d(arr(i, 1)) = ""
    Next
    k = d.Keys
    For i = 0 To UBound(k)
        Set conn = CreateObject("adodb.connection")
        conn.Open "provider=Microsoft.ACE.OLEDB.12.0;extended properties=Excel 12.0;Data Source=" & ThisWorkbook.FullName
        Sql = "select * from [Sheet1$] where " & title & " = \'" & k(i) & "\'"
        Worksheets.Add after:=Sheets(Sheets.Count)
        With ActiveSheet
            .Name = k(i)
            For num = 1 To UBound(myArray)
                .Cells(1, num) = myArray(num, 1)
            Next num
            .Range("A2").CopyFromRecordset conn.Execute(Sql)
        End With
        Sheets(1).Select
        Sheets(1).Cells.Select
        Selection.Copy
        Worksheets(Sheets.Count).Activate
        ActiveSheet.Cells.Select
        Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
        Application.CutCopyMode = False
    Next i
    conn.Close
    Set conn = Nothing
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "拆分Worksheet完毕"
End Sub

 

Sub Split2File()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    Dim titleRange As Range
    Dim title As Variant
    Set titleRange = Application.InputBox(prompt:="请选择拆分的表头,必须是第一行,且为一个单元格,如:“组织”", Type:=8)
    title = titleRange.Value
    c = titleRange.Column
    \'c = Application.InputBox("请输入拆分列号", , 4, , , , , 1)
    If c = 0 Then Exit Sub
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    arr = Worksheets("Sheet1").UsedRange
    lc = UBound(arr, 2)
    Set rng = [a1].Resize(, lc)
    Set d = CreateObject("scripting.dictionary")
    For i = 2 To UBound(arr)
    If Not d.Exists(arr(i, c)) Then
    Set d(arr(i, c)) = Cells(i, 1).Resize(1, lc)
    Else
    Set d(arr(i, c)) = Union(d(arr(i, c)), Cells(i, 1).Resize(1, lc))
    End If
    Next
    k = d.Keys
    t = d.Items
    For i = 0 To d.Count - 1
    With Workbooks.Add(xlWBATWorksheet)
    rng.Copy .Sheets(1).[a1]
    t(i).Copy .Sheets(1).[a2]
    .SaveAs Filename:=ThisWorkbook.Path & "\" & k(i) & ".xls"
    .Close
    End With
    Next
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "完毕"
End Sub

 

分类:

技术点:

相关文章: