ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 根据某列字段拆分多个工作簿

[复制链接]

TA的精华主题

TA的得分主题

发表于 2016-6-19 19:32 | 显示全部楼层 |阅读模式
这是之前版主写的代码  我想问如何保留前7行为表头怎么改楠?
Sub 保留表头拆分数据为若干新工作簿()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    c = Application.InputBox("请输入拆分列号", , 4, , , , , 1)
    If c = 0 Then Exit Sub
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    arr = [a1].CurrentRegion
    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

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2016-6-19 20:59 | 显示全部楼层
上个附件吧。。。。。。

TA的精华主题

TA的得分主题

发表于 2016-6-19 23:32 | 显示全部楼层
代码写的好....................................................................................................

TA的精华主题

TA的得分主题

发表于 2016-6-21 23:46 | 显示全部楼层
On Error Resume Next

Dim wb As Workbook, arr, rng As Range, d As Object, K, t, sh As Worksheet, i&, J As Integer, STR As String
    Set rng = Range(Cells(1, 1), Cells(1, Columns.Count).End(xlToLeft))
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
   STR = InputBox("请输入分拆后的文件名")
    J = InputBox("请输入关键名称在第几列?请输入数字")
    arr = Range(Cells(1, J), Cells(Rows.Count, J).End(xlUp))
    Set d = CreateObject("scripting.dictionary")
    For i = 2 To UBound(arr)
        If Not d.Exists(arr(i, 1)) Then
            Set d(arr(i, 1)) = Cells(i, 1).Resize(1, Columns.Count)
        Else
            Set d(arr(i, 1)) = Union(d(arr(i, 1)), Cells(i, 1).Resize(1, Columns.Count))
        End If
    Next
    K = d.Keys
    t = d.Items
    For i = 0 To d.Count - 1
        Set wb = Workbooks.Add(xlWBATWorksheet)
        With wb.Sheets(1)
            rng.Copy .[A1]
            t(i).Copy .[A2]
        End With
        wb.SaveAs Filename:=ThisWorkbook.Path & "\" & STR & K(i) & ".xlsx"
        wb.Close
    Next
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "表已分拆完毕,拆分后的文件在文件夹中查找"

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2016-12-5 20:51 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 乐乐2006201505 于 2016-12-5 20:52 编辑

Sub 保留表头拆分数据为若干新工作簿()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    c = Application.InputBox("请输入拆分列号", , 4, , , , , 1)
    If c = 0 Then Exit Sub
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    arr = [a1].CurrentRegion
    lc = UBound(arr, 2)
    Set rng = [a1].Resize(6, lc)                                  '本句代码中,偏移行的多少决定保留表头的行数,你要保留7行,就可以将6改为7即可。
    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).[a7]                         '这句中A列数字为几,则拆分后的数据在A列第几行,需要比前面红色注明的数字大1。
            .SaveAs Filename:=ThisWorkbook.Path & "\" & k(i) & ".xls"
            .Close
        End With
    Next
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "完毕"
End Sub

经过上边两步,就可以实现表头留随意几行,你可以试试。希望对你有用,而且希望回答的不是太迟。如果解决了你的问题,请告诉一声。谢谢!


评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2017-1-18 09:29 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
乐乐2006201505 发表于 2016-12-5 20:51
Sub 保留表头拆分数据为若干新工作簿()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    ...

感谢,又学习了,还有,如果我想粘贴到新工作薄的内容是转置粘贴的,怎么实现啊

TA的精华主题

TA的得分主题

发表于 2017-1-18 17:25 | 显示全部楼层
南极烤熊 发表于 2017-1-18 09:29
感谢,又学习了,还有,如果我想粘贴到新工作薄的内容是转置粘贴的,怎么实现啊

传附件,说明要求。

TA的精华主题

TA的得分主题

发表于 2017-5-28 11:10 | 显示全部楼层
乐乐2006201505 发表于 2016-12-5 20:51
Sub 保留表头拆分数据为若干新工作簿()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    ...

你好,如果我需要在拆分后的表格中,都需要按照某种格式来保存,例如都需要把字体变为宋体,把某一列的颜色变为黄色,那么应该在程序中的什么地方修改一下呢?万分感谢!

TA的精华主题

TA的得分主题

发表于 2017-12-11 12:00 | 显示全部楼层
@乐乐2006201505 老师,如果将代码改为在该文件中生成多个子表,改动是不是很方便?

TA的精华主题

TA的得分主题

发表于 2017-12-11 12:01 | 显示全部楼层
乐乐2006201505 发表于 2016-12-5 20:51
Sub 保留表头拆分数据为若干新工作簿()
    Dim arr, d As Object, k, t, i&, lc%, rng As Range, c%
    ...

@乐乐2006201505 老师,如果将代码改为在该文件中生成多个子表,改动是不是很方便?
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-18 19:30 , Processed in 0.046305 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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