前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >VBA拆分工作簿示例

VBA拆分工作簿示例

作者头像
fanjy
发布2024-06-19 14:16:52
600
发布2024-06-19 14:16:52
举报
文章被收录于专栏:完美Excel完美Excel

标签:VBA

如下图1所示,列B中有一系列重复数据,想要将每个重复的数据所在的行放到一个新工作簿并以该数据作为工作簿名。例如,列B中为7890的所有行复制到一个新工作簿并命名为7890.xlsx。

图1

这里借用在vbaexpress.com中找到的一段程序来实现。

代码如下:

代码语言:javascript
复制
Sub test()
 Dim rng As Range, wbDest As Workbook, wsDest As Worksheet, wsCbasis As Worksheet
 Dim DTCCstr As Variant, var As Variant, DTCCcol As New Collection, x As Long
 
 With Application
   .EnableAnimations = False
   .Calculation = xlCalculationManual
   .ScreenUpdating = False
 End With
 
 Set wsCbasis = Sheets("源数据")
 With wsCbasis
   var = .Range("B2:B" & .Range("B" & Rows.Count).End(xlUp).Row)
 
   For x = 0 To UBound(var)
     On Error Resume Next
     DTCCcol.Add var(x, 1), CStr(var(x, 1))
     On Error GoTo 0
   Next x
 
   If Not .AutoFilterMode Then .Range("A1").AutoFilter
   Set rng = .UsedRange
 
   For Each DTCCstr In DTCCcol
     rng.AutoFilter 2, DTCCstr
     rng.SpecialCells(12).Copy
     Set wbDest = Workbooks.Add
     Set wsDest = wbDest.Sheets(1)
     With wsDest.Range("A1")
       .PasteSpecial 8
       .PasteSpecial 12
       .PasteSpecial -4122
     End With
     Application.CutCopyMode = False
     wbDest.SaveAs ThisWorkbook.Path & "/" & DTCCstr & ".xlsx"
     wbDest.Close
   Next DTCCstr
   rng.AutoFilter
 End With
 
 With Application
   .EnableAnimations = True
   .Calculation = xlCalculationAutomatic
   .ScreenUpdating = True
 End With
End Sub

如果你有类似的需求,只需根据实际情况修改代码中工作表的名称,或者数据所有的列。

这也是一个很好的初学者示例,有兴趣的朋友可以边学习边研究其实现过程。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-06-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 完美Excel 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档