ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
123
返回列表 发新帖
楼主: sl8831

[求助] 请教 如何将一个表里两sheet中的数据按相同关键词拆成独立表格

[复制链接]

TA的精华主题

TA的得分主题

发表于 2011-3-15 16:33 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
原帖由 sl8831 于 2011-3-15 16:23 发表
高手我好像看这串程序和之前的没有区别啊

从第二行以下全部删除:
20072010.rar (88.58 KB, 下载次数: 10)

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-15 16:40 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
刚刚又筛了一次 还是不行 都是好几mb 真正的数据其实就几百kb
请您修改一下的代码

Sub Macro1()
    Dim cnn As Object, rs As Object, wb As Workbook, wb1 As Workbook
    Dim SQL$, arr, i%, desk$, Filename, sh As Worksheet, d As Object, av%, s$
    av = Application.Version
    If av <= 11 Then
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls),*.xls", Title:="请选择文件")
        s = ".xls"
    Else
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls;*.xlsx;*.xlsm),*.xls;*.xlsx;*.xlsm", Title:="请选择文件")
        s = ".xls"
    End If
    If TypeName(Filename) = "Boolean" Then Exit Sub
    If Filename = ThisWorkbook.FullName Then
        MsgBox "不能选择本文件!请重新选择"
        Exit Sub
    End If
    arr = Array("1", " 2", "3", "4", "5")
    Set d = CreateObject("scripting.dictionary")
    If Val(Right(Application.OperatingSystem, 4)) >= 6 Then
        desk = Environ("USERPROFILE") & "\Desktop\"
    Else
        desk = Environ("USERPROFILE") & "\桌面\"
    End If
    Set cnn = CreateObject("ADODB.Connection")
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set wb = Workbooks.Open(Filename)
    If av <= 11 Then
        cnn.Open "provider=Microsoft.Jet.OLEDB.4.0;extended properties=excel 8.0;data source=" & Filename
    Else
        cnn.Open "Provider=Microsoft.Ace.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & Filename
    End If
    For Each sh In wb.Sheets
        If Len(SQL) Then SQL = SQL & " union all "
        SQL = SQL & "Select distinct 单位 From [" & sh.Name & "$]"
    Next
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open SQL, cnn, 1, 3
    For i = 1 To rs.RecordCount
        d(rs.Fields(0).Value) = ""
        rs.MoveNext
    Next
    For i = 0 To UBound(arr)
        If d.Exists(arr(i)) Then
            wb.SaveCopyAs desk & arr(i) & s
            Set wb1 = Workbooks.Open(desk & arr(i) & s)
            For Each sh In wb1.Sheets
                SQL = "Select * From [" & sh.Name & "$] Where 单位='" & arr(i) & "'"
                Set rs = CreateObject("ADODB.Recordset")
                rs.Open SQL, cnn, 1, 3
                If rs.RecordCount > 0 Then
                    With sh
                        .Activate
                        .[a1].Select
                        lr = .[a1].CurrentRegion.Rows.Count
                        .[a1].CurrentRegion.Offset(1 + rs.RecordCount).Clear
                        .[A2].CopyFromRecordset rs
                    End With
                    ActiveWindow.SmallScroll Down:=lr * (-1)
                Else
                    sh.Delete
                End If
            Next
            wb1.Close True
        End If
    Next
    wb.Close False
    rs.Close
    cnn.Close
    Set rs = Nothing
    Set cnn = Nothing
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "ok"
End Sub

TA的精华主题

TA的得分主题

发表于 2011-3-15 16:47 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
原帖由 sl8831 于 2011-3-15 16:40 发表
刚刚又筛了一次 还是不行 都是好几mb 真正的数据其实就几百kb
请您修改一下的代码

Sub Macro1()
    Dim cnn As Object, rs As Object, wb As Workbook, wb1 As Workbook
    Dim SQL$, arr, i%, desk$, File ...

Sub Macro1()
    Dim cnn As Object, rs As Object, wb As Workbook, wb1 As Workbook
    Dim SQL$, arr, i%, desk$, Filename, sh As Worksheet, d As Object, av%, str1$, s$, pinyin$
    Dim hp As HZ2PY
    av = Application.Version
    If av <= 11 Then
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls),*.xls", Title:="请选择文件")
    Else
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls;*.xlsx;*.xlsm),*.xls;*.xlsx;*.xlsm", Title:="请选择文件")
    End If
    If TypeName(Filename) = "Boolean" Then Exit Sub
    If Filename = ThisWorkbook.FullName Then
        MsgBox "不能选择本文件!请重新选择"
        Exit Sub
    End If
    arr = Split(Filename, ".")
    If arr(UBound(arr)) = "xls" Then str1 = ".xls" Else str1 = ".xlsx"
    Set hp = New HZ2PY
    hp.InitialOnly = False
    hp.OnlyOneChar = True
    arr = Array("河南郑州", "河南洛阳", "河南新乡", "福建福州", "福建厦门", "福建泉州", "安徽合肥")
    Set d = CreateObject("scripting.dictionary")
    If Val(Right(Application.OperatingSystem, 4)) >= 6 Then s = "\Desktop\" Else s = "\桌面\"
    desk = Environ("USERPROFILE") & s
    Set cnn = CreateObject("ADODB.Connection")
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set wb = Workbooks.Open(Filename)
    If av <= 11 Then
        cnn.Open "provider=Microsoft.Jet.OLEDB.4.0;extended properties=excel 8.0;data source=" & Filename
    Else
        cnn.Open "Provider=Microsoft.Ace.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & Filename
    End If
    For Each sh In wb.Sheets
        If Len(SQL) Then SQL = SQL & " union all "
        SQL = SQL & "Select distinct 地区 From [" & sh.Name & "$]"
    Next
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open SQL, cnn, 1, 3
    For i = 1 To rs.RecordCount
        d(rs.Fields(0).Value) = ""
        rs.MoveNext
    Next
    For i = 0 To UBound(arr)
        If d.Exists(arr(i)) Then
            s = arr(i)
            pinyin = hp.AdjustPhoneticNotation(hp.GetPinYin(s), pnNoNotation)
            wb.SaveCopyAs desk & pinyin & str1
            Set wb1 = Workbooks.Open(desk & pinyin & str1)
            For Each sh In wb1.Sheets
                SQL = "Select * From [" & sh.Name & "$] Where 地区='" & arr(i) & "'"
                Set rs = CreateObject("ADODB.Recordset")
                rs.Open SQL, cnn, 1, 3
                If rs.RecordCount > 0 Then
                    With sh
                        .Activate
                        .[a1].Select
                        lr = .[a1].CurrentRegion.Rows.Count
'                        .UsedRange.Offset(1).EntireRow.Delete
                        .Rows("2:" & Cells.Rows.Count).Delete '从第二行到最后以行全部删除
                        .[A2].CopyFromRecordset rs
                    End With
                    ActiveWindow.SmallScroll Down:=lr * (-1)
                Else
                    sh.Delete
                End If
            Next
            wb1.Close True
        End If
    Next
    wb.Close False
    rs.Close
    cnn.Close
    Set rs = Nothing
    Set cnn = Nothing
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "ok"
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-15 17:35 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
谢谢高手 很强大

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-17 11:07 | 显示全部楼层

回复 23楼 zhaogang1960 的帖子

高手还要麻烦你一下  请修改一下下面的代码 现在的表是只有一个sheet  按 总代 筛选出 1 2 3 4  的数据 并以1 2 3 4  命名 sheet的名字也要一致  保存在桌面 谢谢
还有一个小建议 可以打开的是什么格式的就保存成什么格式么 比如打开的是03版 .xls的 但是筛好后就保存为xlsx的了 就看不了了 所以想打开为xls保存为xls   打开为xlsx保存为xlsx  

Sub Macro1()
    Dim cnn As Object, rs As Object, wb As Workbook, wb1 As Workbook
    Dim SQL$, arr, i%, desk$, Filename, sh As Worksheet, d As Object, av%, s$
    av = Application.Version
    If av <= 11 Then
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls),*.xls", Title:="请选择文件")
        s = ".xls"
    Else
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls;*.xlsx;*.xlsm),*.xls;*.xlsx;*.xlsm", Title:="请选择文件")
        s = ".xls"
    End If
    If TypeName(Filename) = "Boolean" Then Exit Sub
    If Filename = ThisWorkbook.FullName Then
        MsgBox "不能选择本文件!请重新选择"
        Exit Sub
    End If
    arr = Array("1", " 2", "3", "4", "5")
    Set d = CreateObject("scripting.dictionary")
    If Val(Right(Application.OperatingSystem, 4)) >= 6 Then
        desk = Environ("USERPROFILE") & "\Desktop\"
    Else
        desk = Environ("USERPROFILE") & "\桌面\"
    End If
    Set cnn = CreateObject("ADODB.Connection")
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set wb = Workbooks.Open(Filename)
    If av <= 11 Then
        cnn.Open "provider=Microsoft.Jet.OLEDB.4.0;extended properties=excel 8.0;data source=" & Filename
    Else
        cnn.Open "Provider=Microsoft.Ace.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & Filename
    End If
    For Each sh In wb.Sheets
        If Len(SQL) Then SQL = SQL & " union all "
        SQL = SQL & "Select distinct 单位 From [" & sh.Name & "$]"
    Next
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open SQL, cnn, 1, 3
    For i = 1 To rs.RecordCount
        d(rs.Fields(0).Value) = ""
        rs.MoveNext
    Next
    For i = 0 To UBound(arr)
        If d.Exists(arr(i)) Then
            wb.SaveCopyAs desk & arr(i) & s
            Set wb1 = Workbooks.Open(desk & arr(i) & s)
            For Each sh In wb1.Sheets
                SQL = "Select * From [" & sh.Name & "$] Where 单位='" & arr(i) & "'"
                Set rs = CreateObject("ADODB.Recordset")
                rs.Open SQL, cnn, 1, 3
                If rs.RecordCount > 0 Then
                    With sh
                        .Activate
                        .[a1].Select
                        lr = .[a1].CurrentRegion.Rows.Count
                        .[a1].CurrentRegion.Offset(1 + rs.RecordCount).Clear
                        .[A2].CopyFromRecordset rs
                    End With
                    ActiveWindow.SmallScroll Down:=lr * (-1)
                Else
                    sh.Delete
                End If
            Next
            wb1.Close True
        End If
    Next
    wb.Close False
    rs.Close
    cnn.Close
    Set rs = Nothing
    Set cnn = Nothing
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "ok"
End Sub

123.rar

18.38 KB, 下载次数: 1

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-17 11:11 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
或者您可以帮我 做一个 可以我自己改 筛选条件的代码么 每次筛的表格都大同小异 就是已其中一列 筛自己想要的数据 保存在桌面 我想实现的就是 自己填写筛哪列 自己填写筛这列的那些数据 运行加载表格 就筛到桌面了 不知道可不可以实现 谢谢

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-18 12:23 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

回复 23楼 zhaogang1960 的帖子

高手在么?
高手还要麻烦你一下  请修改一下下面的代码 现在的表是只有一个sheet  按 总代 筛选出 1 2 3 4  的数据 并以1 2 3 4  命名 sheet的名字也要一致  保存在桌面 谢谢
还有一个小建议 可以打开的是什么格式的就保存成什么格式么 比如打开的是03版 .xls的 但是筛好后就保存为xlsx的了 就看不了了 所以想打开为xls保存为xls   打开为xlsx保存为xlsx  

Sub Macro1()
    Dim cnn As Object, rs As Object, wb As Workbook, wb1 As Workbook
    Dim SQL$, arr, i%, desk$, Filename, sh As Worksheet, d As Object, av%, s$
    av = Application.Version
    If av <= 11 Then
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls),*.xls", Title:="请选择文件")
        s = ".xls"
    Else
        Filename = Application.GetOpenFilename(FileFilter:="Excel 工作簿文件 (*.xls;*.xlsx;*.xlsm),*.xls;*.xlsx;*.xlsm", Title:="请选择文件")
        s = ".xls"
    End If
    If TypeName(Filename) = "Boolean" Then Exit Sub
    If Filename = ThisWorkbook.FullName Then
        MsgBox "不能选择本文件!请重新选择"
        Exit Sub
    End If
    arr = Array("1", " 2", "3", "4", "5")
    Set d = CreateObject("scripting.dictionary")
    If Val(Right(Application.OperatingSystem, 4)) >= 6 Then
        desk = Environ("USERPROFILE") & "\Desktop\"
    Else
        desk = Environ("USERPROFILE") & "\桌面\"
    End If
    Set cnn = CreateObject("ADODB.Connection")
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set wb = Workbooks.Open(Filename)
    If av <= 11 Then
        cnn.Open "provider=Microsoft.Jet.OLEDB.4.0;extended properties=excel 8.0;data source=" & Filename
    Else
        cnn.Open "Provider=Microsoft.Ace.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & Filename
    End If
    For Each sh In wb.Sheets
        If Len(SQL) Then SQL = SQL & " union all "
        SQL = SQL & "Select distinct 单位 From [" & sh.Name & "$]"
    Next
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open SQL, cnn, 1, 3
    For i = 1 To rs.RecordCount
        d(rs.Fields(0).Value) = ""
        rs.MoveNext
    Next
    For i = 0 To UBound(arr)
        If d.Exists(arr(i)) Then
            wb.SaveCopyAs desk & arr(i) & s
            Set wb1 = Workbooks.Open(desk & arr(i) & s)
            For Each sh In wb1.Sheets
                SQL = "Select * From [" & sh.Name & "$] Where 单位='" & arr(i) & "'"
                Set rs = CreateObject("ADODB.Recordset")
                rs.Open SQL, cnn, 1, 3
                If rs.RecordCount > 0 Then
                    With sh
                        .Activate
                        .[a1].Select
                        lr = .[a1].CurrentRegion.Rows.Count
                        .[a1].CurrentRegion.Offset(1 + rs.RecordCount).Clear
                        .[A2].CopyFromRecordset rs
                    End With
                    ActiveWindow.SmallScroll Down:=lr * (-1)
                Else
                    sh.Delete
                End If
            Next
            wb1.Close True
        End If
    Next
    wb.Close False
    rs.Close
    cnn.Close
    Set rs = Nothing
    Set cnn = Nothing
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "ok"
End Sub

123.rar

18.38 KB, 下载次数: 1

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-3-20 16:48 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

回复 21楼 zhaogang1960 的帖子

高手 请帮忙看看上面的问题

TA的精华主题

TA的得分主题

发表于 2018-8-23 17:51 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-12 19:06 , Processed in 0.023835 second(s), 7 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表