VBA编程,合并多个工作表到一个表,源代码
haoteby 2025-01-10 13:47 11 浏览
以前做了几个合并工作表的示例,大多可根据要求实现,当工作过程中再次应用的时候,发现以前的内容有点不适合,由于工作表结构变化,其使用过程中出了一些并不符合的现象。
实现流程
本节将利用vba代码,实现从多个工作薄中提取所有不为空表的工作表,合并到一个新建工作表中,实现多表合一。
可以实现工作表汇总,把各分部汇总的表统一进行整合的场景下,使用更加方便。
合并之后如下图所示:
合并的前提是工作表结构要相同,当然,不相同也可以,可能再次进行计算处理的时候,要进行修整操作。
本示例进行的是一个傻瓜式合并,也就是不管三七二十一,进行数据追加合并,不会考虑工作表的结构是否一致。
当然了,空表是不会合并的,代码中进行了一筛选。
代码
代码是整个操作的一个灵魂,如果完整理解了代码中的过程方法,那么就对工作表合并有了一个基本认识。
执行入口
Private Sub JoinSheet()
Application.Caption = "江觅"
Dim NewWork As Workbook, xName As String
xName = Application.InputBox("输入工作薄名称", "合并工作表", VBA.Format(VBA.Date, "yyyymmdd") & VBA.Format(VBA.Time, "hhmm"))
If VBA.Len(xName) = 0 Then Exit Sub
If xName = False Then Exit Sub
Set NewWork = Application.Workbooks.Add()
NewWork.SaveAs ThisWorkbook.Path & "\" & xName & ".xlsx"
Dim si As Integer
With Application.FileDialog(msoFileDialogFilePicker)
If .Show = -1 Then
.Filters.Clear
.Filters.Add "Excle文件", "*.xls;*.xlsx"
.AllowMultiSelect = True
For si = 1 To .SelectedItems.Count '遍历打开工作表
SelectCopySheet .SelectedItems(si), NewWork
Next si
MsgBox xName & VBA.vbCrLf & "复制完成。", vbInformation, "成功"
End If
End With
End Sub
循环
遍历要复制的工作表,并调用合并函数
Public Sub SelectCopySheet(xWorkName As String, NewWork As Workbook)
'选择工作表,调用复制表内容函数
On Error Resume Next
Dim s As Workbook
Application.Workbooks.Open xWorkName
Set s = ActiveWorkbook
Dim xSheet As Worksheet, R As Range
For Each xSheet In s.Worksheets
Set R = CheckIsBlack(xSheet)
If Not R Is Nothing Then '如果不是空表
CopySheetToNewSheet R, NewWork '复制工作表
End If
Next xSheet
s.Close
Set R = Nothing
Set xSheet = Nothing
Set s = Nothing
End Sub
追加复制
Public Sub CopySheetToNewSheet(R As Range, NewWork As Workbook)
'追加复制内容到新工作表
On Error Resume Next
Application.ScreenUpdating = False
Application.DisplayAlerts = False
Dim xSheet As Worksheet
Dim wr As Integer, wc As Integer
Set xSheet = NewWork.Worksheets(1)
wr = xSheet.UsedRange.Rows.Count + 1
wc = xSheet.UsedRange.Columns.Count
If wr = 2 Then wr = 1
xSheet.Cells(wr, 1).Select
R.Copy
xSheet.Cells(wr, 1).PasteSpecial xlPasteAll
NewWork.Save
Set xSheet = Nothing
Application.ScreenUpdating = True
Application.DisplayAlerts = True
End Sub
整个过程实现后可以得到一个新工作薄,工作薄名称以日期和日期合并得到字符,也可根据自己实际情况进行修改。
欢迎关注、收藏
---END---
- 上一篇:Qt开发-文件的读写操作
- 下一篇:ACCESS-按WORD模板格式输出代码2
相关推荐
- 能跑源码,还提供数据集:这里有一个入门企业级验证码识别项目
-
机器之心专栏作者:kerlomz网上关于验证码识别的开源项目众多,但大多是学术型文章或者仅仅是一个测试demo,那么企业级的验证码识别究竟是怎样的呢?1.前言网上关于验证么识别的开源项目众多,但大...
- kdj源码_kdj源码公式描述
-
N:=9;M1:=3;M2:=3;...
- QT实现抖动文字和滚动文字,附源码
-
前言不知道大家有没有发现今天的文章有什么不一样,哈哈,我自己胡拼乱凑弄了一个logo,好不好看就先不说了,最起码萌萌哒...当然这不是今天的重点,在做logo的时候,我原本想让文字动起来的,奈何技术有...
- 我试图通过这篇文章告诉你,这行源码有多牛逼。
-
你好呀,我是歪歪。这次给你盘一个特别有意思的源码,正如我标题说的那样:看懂这行源码之后,我不禁鼓起掌来,直呼祖师爷牛逼。...
- 想了解Python源代码加密吗?现总结如下5大加密混淆手段!
-
我们在进行...
- Android系统基础(03) Android系统源码下载
-
常规官方网站说明:Android源码官方网站为(google你懂的):https://source.android.com官网参考链接,对应的tag(tag是一种标签,我们可以根据tag来判断下载的...
- 真香,Python爬取B站弹幕原来如此简单,源码已附在文末
-
B站的弹幕区一直是人才圣地。今天我就用python来手把手教大家爬取B站排行榜热门视频,Python爬取视频也可以如此简单。...
- 最详细的 maven 教程,可以收藏_maven步骤
-
链接|cnblogs.com/hzg110/p/6936101.html正文目前所有的项目都在使用maven,可是一直没有时间去整理学习,这两天正好有时间,好好的整理一下。...
- Python黑科技-VIP视频破解源码分享
-
《利用Python制作自己的VIP视频解析软件》想看的电视剧更新了还要充VIP?喜欢的电影你是VIP还得付费?学了Python哪要这些花里胡哨的,打开我自己的VIP付费视频解析软件,想怎么看就怎么看!...
- 抖音无水印解析网站源码_抖音无水印解析平台
-
链接:https://share.weiyun.com/59Ah44S密码:hv4dm7上传到主机解压不用安装,直接打开域名就可以了原文地址:https://www.xigsc.com/post/...
- 「电脑知识」USBOS 3.0 v2022.1.24 超级PE启动维护工具标准增强版
-
前几天一直在发PE类工具就是为了制作U盘PE启动重装系统教程的,今天小编继续分享有一篇关于pe的之前小编发布过一款微PE工具箱,今天发布另外一个无任何流氓行为功能超级强大虽然体积大了一点,但是这个...
- 模版网站建设制作的八步流程_模板的网站
-
模版网站比较简单,一般我们按照如下流程就可以制作出来。 一、网站定位: 在建站之前,一定要了解你要建的网站是什么。你必须考虑你网站的标题(关键词)、网站描述以及你想要建立的网站。 二、选择域...
- 求职季必备,这几个免费的个人简历模板网站,你可千万不要错过!
-
晃晃悠悠又到了春招的季节,相信一定有很多小伙伴趁着这个金三银四求职季,四处投递简历。这时候一个亮眼优秀的简历,可以很好的祝你吸引HR的注意。今天就把我珍藏很久的5个免费简历模板网站分享给大家,简历模板...
- 简约时尚作品博客商店网站HTML5模板源码
-
Meduza是简约时尚和现代的博客HTML模板,带商店电商元素的博客页面。考虑所有的作品集网站需求页可以设计一个旅游网站。原生响应设计HTML5和CSS3(台式机、平板电脑、手机…)简单,干净的和专业...
- 13 款免费样机网站合集,UI设计、产品设计、VI设计全都有!
-
俗话说得好,人靠衣装,在作完设计后不少设计师都会为自己的作品套一个「样机」好让设计看过去更加高端大气上档次!今天,我就总结了无论是UI设计、包装设计、服装设计、品牌设计、logo设计,都能用到...