ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 3045|回复: 28

[求助] 多表按部门自动拆分为多工作簿问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-6-9 12:55 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
述求:当前工作簿目录有三张表(有可能增加),每张表中都有部门这个字段,要求按部门自动拆分为有三张表的以部门名为名的多工作簿。

单表按条件拆分为多工作簿,这个操作常见,但多表按条件拆分为多表工作簿,这个操作少见。

求高手出手相助。叩谢!

多表按部门拆分为多工作簿问题.zip

156.11 KB, 下载次数: 43

TA的精华主题

TA的得分主题

发表于 2021-6-9 13:49 | 显示全部楼层
这个工具应该是可以满足你的需求的,自己看看

TA的精华主题

TA的得分主题

发表于 2021-6-9 13:55 | 显示全部楼层
不明白你想怎樣, 你把分拆後的結果弄出來看看

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-6-9 14:10 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
jack5d 发表于 2021-6-9 13:55
不明白你想怎樣, 你把分拆後的結果弄出來看看

就是按原工作簿的工作表结构,把单一部门的数据拆分出来,自动拆分所有部门的数据。

车商二部.zip

12.28 KB, 下载次数: 15

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-6-9 14:13 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
3190496160 发表于 2021-6-9 13:49
这个工具应该是可以满足你的需求的,自己看看

我先看看,好象有我需要的。

TA的精华主题

TA的得分主题

发表于 2021-6-9 14:14 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2021-6-9 14:19 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 opel-wong 于 2021-6-9 15:10 编辑

代码如下,供参考:
  1. Sub 条件拆分()
  2.     Dim T1 As Date: T1 = Timer
  3.     Dim arr, i As Long, bm As String, mFile As String, mPath As String
  4.     Dim Rng As Range, sht As Worksheet, Key
  5.     Dim d As Object: Set d = CreateObject("Scripting.Dictionary")
  6.     For Each sht In Worksheets
  7.         arr = sht.UsedRange.Value
  8.         For i = 4 To UBound(arr)
  9.             bm = arr(i, 5)
  10.             If Len(bm) > 0 And InStr(bm, "部门") = 0 And Not d.Exists(bm) Then d(bm) = Empty
  11.         Next
  12.     Next
  13.     Application.ScreenUpdating = False
  14.     mPath = ThisWorkbook.Path & "\生成报表\"   ' 报表生成路径,可自行修改
  15.     If Dir(mPath, vbDirectory) = "" Then MkDir mPath  ' 若文件夹不存在,则建立
  16.     For Each Key In d.keys
  17.         Worksheets.Copy
  18.         For Each sht In Worksheets
  19.             With sht
  20.                 arr = .UsedRange.Value
  21.                 For i = 4 To UBound(arr)
  22.                     bm = arr(i, 5)
  23.                     If Len(bm) > 0 And InStr(bm, "部门") = 0 And bm <> Key Then
  24.                         If Rng Is Nothing Then Set Rng = .Rows(i) Else Set Rng = Application.Union(Rng, .Rows(i))
  25.                     End If
  26.                 Next
  27.             End With
  28.             If Not Rng Is Nothing Then Rng.Delete: Set Rng = Nothing
  29.         Next
  30.         mFile = mPath & Key & ".xlsx"
  31.         If Dir(mFile, vbHidden + vbNormal) <> "" Then Kill mFile    ' 若同名文件存在,则删除
  32.         ActiveWorkbook.SaveAs mFile, xlOpenXMLWorkbook  ' 另存
  33.         ActiveWorkbook.Close    ' 关闭
  34.     Next
  35.     Application.ScreenUpdating = True
  36.     MsgBox "表格已按部门拆分完成,用时约:" & Format(Timer - T1, "0.0" & " 秒!"), 64 + 0, "温馨提醒"
  37. End Sub
复制代码


TA的精华主题

TA的得分主题

 楼主| 发表于 2021-6-9 15:13 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
opel-wong 发表于 2021-6-9 14:14
代码如下,供参考:

试了一下,基本能够满足要求。谢谢。

TA的精华主题

TA的得分主题

发表于 2021-6-9 15:34 | 显示全部楼层
ykcbf1100 发表于 2021-6-9 15:13
试了一下,基本能够满足要求。谢谢。

你要求可以的哈,还基本满足要求!
牛逼!

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-6-9 16:19 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
opel-wong 发表于 2021-6-9 15:34
你要求可以的哈,还基本满足要求!
牛逼!

可能我没说清楚,我其实是想把拆分后的工作簿放在当前目录下的。但根据你的代码运行后发现拆分后的工作簿放在上一级的目录下了,不知道什么原因,我也没仔细去查。我根据你的代码修改了一下,现在是能够满足我自己的要求了。谢谢你了。不过说真的,我其实并没有完全理解你的代码。以下是我稍加修改后的代码:
Sub 多表按部门拆分()
    Dim Start As Double, Finish As Double   '运行时间
    Start = Timer
    Dim arr, i As Long, bm$, mFile$
    Dim Rng As Range, sht As Worksheet, Key
    Dim d As Object
    Set d = CreateObject("Scripting.Dictionary")
    For Each sht In Worksheets
        If sht.Name <> "拆分台" Then
            arr = sht.UsedRange.Value
            For i = 4 To UBound(arr)
                bm = arr(i, 5)
                If Len(bm) > O And InStr(bm, "部门") = 0 And Not d.Exists(bm) Then
                    d(bm) = Empty
                End If
            Next
        End If
    Next
    Application.ScreenUpdating = False
    For Each Key In d.keys
        If Key <> 0 Then                       '//排除部门为0的部门
            Worksheets.Copy
            For Each sht In Worksheets
                If sht.Name <> "拆分台" Then
                    With sht
                        arr = .UsedRange.Value
                        For i = 4 To UBound(arr)
                            bm = arr(i, 5)
                            If Len(bm) > O And InStr(bm, "部门") = 0 And bm <> Key Then
                                If Rng Is Nothing Then
                                    Set Rng = .Rows(i)
                                Else
                                    Set Rng = Application.Union(Rng, .Rows(i))
                                End If
                            End If
                        Next
                    End With
                    If Not Rng Is Nothing Then
                        Rng.Delete
                    End If
                    Set Rng = Nothing
                End If
            Next
            mFile = Key & ".xlsx"
            If Dir(mFile, vbHidden + vbNormal) <> "" Then
                Kill mFile                                    '//若同名文件存在,则删除
            End If
            ActiveWorkbook.Sheets("拆分台").Select
            Application.DisplayAlerts = False                '//关闭系统提示
            ActiveWindow.SelectedSheets.Delete               '//删除多余表
            Application.DisplayAlerts = True                 '//恢复系统提示
            ActiveWorkbook.SaveAs Filename:=ThisWorkbook.Path & "\" & mFile, FileFormat:=51    '原格式另存为一个新工作簿
            ActiveWorkbook.Close 关闭
        End If
    Next
    Application.ScreenUpdating = True
    Finish = Timer
    MsgBox "数据拆分完毕,共用时:" & Finish - Start & "秒"
End Sub



多表按部门拆分为多工作簿.zip

167.18 KB, 下载次数: 47

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-6-29 23:18 , Processed in 0.031244 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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