ExcelHome技术论坛

 找回密码
 免费注册
QQ登录 只需一步,快速开始
新浪微博登陆 只需一步, 快速开始
   
高效办公必会的Office99uu优优 永久免费,网表让Excel秒变数据库 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
Excel不给力? 何不试试FoxTable! 国内首部Excel函数公式学习大典 职场充电黑科技, Office微99uu优优 免费下载Excel行业应用视频
300集Office 2010微99uu优优 Tableau-数据可视化工具 突破Excel限制,用活字格提高效率 12门Excel免费公开课任你学
你的Excel 201099uu优优学习锦囊 欲罢不能, 过目难忘的 Office 新界面 免费的Excel考勤计算系统
查看: 150|回复: 8
打印 上一主题 下一主题

[求助] 如何将一个工作簿按门店名称分成不同工作簿

[复制链接]
TA的精华主题TA的得分主题
跳转到指定楼层
1
发表于 2017-8-12 23:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 macky_78 于 2017-8-12 23:29 编辑

book1.rar (29.79 KB, 下载次数: 8) 如附件所示,能否将sheet1按门店名称分列不同的工作簿,同一个工作簿里面按姓名分成不同的工作表。比如以“南昌红谷滩新区鹿暻店机构”为文件名的工作簿里面含有张三的工资表、李四的工资表等按姓名分为不同的工作表。请大师们帮帮忙,不会用宏,谢谢了~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 有用有用 无用无用 分享到新浪微博
TA的精华主题TA的得分主题
2
发表于 2017-8-12 23:40 | 只看该作者
工作表里要哪些字段?
每个人一个工作表吗?你模拟一个,截图看看。
TA的精华主题TA的得分主题
3
发表于 2017-8-12 23:46 | 只看该作者
先按列拆分成工作簿,再拆分成工作表,有实例,自己找找看。
TA的精华主题TA的得分主题
4
 楼主| 发表于 2017-8-12 23:51 | 只看该作者 |楼主
lsc900707 发表于 2017-8-12 23:46
先按列拆分成工作簿,再拆分成工作表,有实例,自己找找看。

嗯嗯 已经找到了
Sub SplitDataToWB() 'bajifeng
'功能:依据部门不同拆分工作表,并分别将同一部门的所有数据存放在一个新工作簿中,并将此新工作簿的文件名按部门的名称命名。
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set D = CreateObject("scripting.dictionary")
    lr = [a65536].End(3).Row
    arr = Range([d2], Cells(lr, "d"))
    For Each a In arr
        If a <> "" Then D(a) = ""
    Next
    For Each k In D.keys
        ActiveWorkbook.Sheets(1).[a1].CurrentRegion.Copy
        Workbooks.Add
        ActiveWorkbook.Sheets(1).Paste
        For i = UBound(arr) To 1 Step -1
            If arr(i, 1) <> k Then Cells(i + 1, "d").EntireRow.Delete
            Next
        ActiveWorkbook.SaveAs ThisWorkbook.Path & "\" & k
        ActiveWorkbook.Close
    Next
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "处理完毕!"
End Sub

大侠,用这个宏正好能拆分,但是能帮忙解释下这个是什么意思吗
TA的精华主题TA的得分主题
5
发表于 2017-8-12 23:54 | 只看该作者
macky_78 发表于 2017-8-12 23:51
嗯嗯 已经找到了
Sub SplitDataToWB() 'bajifeng
'功能:依据部门不同拆分工作表,并分别将同一部门的 ...

这个是用字典数组法写的,又快又好。你自己先看看有关知识吧。
TA的精华主题TA的得分主题
6
 楼主| 发表于 2017-8-12 23:59 | 只看该作者 |楼主
lsc900707 发表于 2017-8-12 23:54
这个是用字典数组法写的,又快又好。你自己先看看有关知识吧。

好的 谢谢大师
TA的精华主题TA的得分主题
7
发表于 2017-8-13 08:40 | 只看该作者
  • Sub test()
  •   Dim r%, i%
  •   Dim arr, brr
  •   Dim wb As Workbook
  •   Dim ws As Worksheet
  •   Dim d As Object
  •   Application.ScreenUpdating = False
  •   Application.DisplayAlerts = False
  •   Set d = CreateObject("scripting.dictionary")
  •   With Worksheets("sheet1")
  •     r = .Cells(.Rows.Count, 1).End(xlUp).Row
  •     arr = .Range("a1:k" & r)
  •     For i = 1 To UBound(arr)
  •       If Not d.exists(arr(i, 4)) Then
  •         Set d(arr(i, 4)) = CreateObject("scripting.dictionary")
  •       End If
  •       If Not d(arr(i, 4)).exists(arr(i, 8)) Then
  •         Set d(arr(i, 4))(arr(i, 8)) = .Range("a1:k1")
  •       End If
  •       Set d(arr(i, 4))(arr(i, 8)) = Union(d(arr(i, 4))(arr(i, 8)), .Cells(i, 1).Resize(1, 11))
  •     Next
  •   End With
  •   For Each aa In d.keys
  •     Application.SheetsInNewWorkbook = d(aa).Count
  •     Set wb = Workbooks.Add
  •     With wb
  •       k = 0
  •       For Each bb In d(aa).keys
  •         k = k + 1
  •         With .Worksheets(k)
  •           .Name = bb
  •           d(aa)(bb).Copy .Range("a1")
  •         End With
  •       Next
  •       .SaveAs Filename:=ThisWorkbook.Path & "" & aa
  •       .Close False
  •     End With
  •   Next
  • End Sub
  • 复制代码
    TA的精华主题TA的得分主题
    8
    发表于 2017-8-13 08:40 | 只看该作者
    详见附件。
    Book1.rar 40.61 KB, 下载次数: 23
    TA的精华主题TA的得分主题
    9
     楼主| 发表于 2017-8-17 00:22 | 只看该作者 |楼主
    您需要登录后才可以回帖 登录 | 免费注册 新浪微博登陆
    本版积分规则
    关闭

    最新热点上一条 /1 下一条

    关注官方微信,每天坐享新鲜教程
    手机版|关于我们|联系我们|ExcelHome    GMT+8, 2017-11-18 23:31 , Processed in 0.174590 second(s), 23 queries , Gzip On, MemCache On.
    Powered by Discuz! X3.3 © 2001-2017 Wooffice Inc.
        沪公网安备 31011702000001号 沪ICP备11019229号 本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:徐怀玉律师 李志群律师
    快速回复 返回顶部 返回列表
    99uu优优