全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
使用VBA合并多个Excel工作簿例如,需要将多个Excel工作簿中的工作表合并到一个工作簿。这里假设需要合并的工作簿在“D:示例数据记录”文件夹中,含有两个工作簿test1.xls、test2.xls(当然,可以不限于两个),在test1.xls工作簿中含有三张工作表,在test2.xls工作簿中含有两张工作表,现在使用一段VBA代码合并这两个工作簿到一个新工作簿中,合并到新工作簿中的工作表分别以原工作簿名加索引值命名。代码如下:Sub CombineWorkbooks() Dim strFileName As String Dim wb As Workbook Dim wsAs Object 包含工作簿的文件夹,可根据实际修改ConststrFileDir As String = D:示例数据记录Application.ScreenUpdating = False Set wb = Workbooks.Add(xlWorksheet)strFileName = Dir(strFileDir& *.xls*) Do While strFileNamevbNullString Dim wbOrig As Workbook Set wbOrig = Workbooks.Open(Filename:=strFileDir&strFileName, ReadOnly:=True)strFileName = Left(Left(strFileName, Len(strFileName) - 4), 29) For Each wsInwbOrig.Sheetsws.Copy After:=wb.Sheets(wb.Sheets.Count) If wbOrig.Sheets.Count 1 Thenwb.Sheets(wb.Sheets.Count).Name = strFileName&ws.Index Elsewb.Sheets(wb.Sheets.Count).Name = strFileName End If NextwbOrig.CloseSaveChanges:=FalsestrFileName = DirLoopApplication.DisplayAlerts = Falsewb.Sheets(1).DeleteApplication.DisplayAlerts = TrueApplication.ScreenUpdating = True Set wb = NothingEnd Sub2.下面是合并多个Excel工作簿的另一种情形,也是Excel VBA实战技巧精粹中所介绍的方法,即合并汇总。有四个工作簿,分别为:汇总工作簿.xls、一月.xls、二月.xls、三月.xls,其中一月.xls、二月.xls、三月.xls均只含有一张工作表且工作表中的数据均自单元格A1开始,现在要求将它们合并至“汇总工作簿.xls”中。在“汇总工作簿.xls”中打开VBE,并输入下列代码:Sub ConsolidateWorkbook() Dim RangeArray() As String Dim bk As Workbook Dim sht As Worksheet Dim WbCountAs IntegerWbCount = Workbooks.CountReDimRangeArray(1 To WbCount - 1) For Each bk In Workbooks 在所有工作簿中循环 If Not bk Is ThisWorkbook Then 非代码所在工作簿 Set sht = bk.Worksheets(1) 引用工作簿的第一个工作表 i = i + 1RangeArray(i) = &bk.Name& &sht.Name& ! & _sht.Range(A1).CurrentRegion.Address(ReferenceStyle:=xlR1C1) End If NextWorksheets(1).Range(A1).Consolidate _RangeArray, xlSum, True, TrueEnd Sub3.下面是汇总多个工作簿的又一种情形,也是一名网友提出的问题:在同一文件夹中有多个工作簿,其中有一个用于汇总的工作簿,要求将除该汇总工作簿外的其它工作簿中的第一张工作表的数据汇总到该汇总工作簿中。代码如下:Sub UnionWorksheets()Application.ScreenUpdating = False Dim lj As String Dim dirname As String Dim nm As Stringlj = ActiveWorkbook.Pathnm = ActiveWorkbook.Namedirname = Dir(lj& *.xls*)Cells.Clear Do Whiledirname If dirname nm ThenWorkbooks.Open Filename:=lj& &dirnameWorkbooks(nm).Activate 复制新打开工作簿的第一个工作表的已用区域到当前工作表Workbooks(dirname).Sheets(1
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业债务合伙协议书
- 商务英语函电(第二版)课件 2.1.4找客户方法-交易会
- 心理咨询师工作计划及客户心理评估方案
- 心理健康与社区工作者培训内容梳理
- 古巴电厂投资分析报告及市场前景预测
- (完整版)数学初一分班模拟题目及解析
- (完整版)数学北师大六年级下册期末必考知识点试卷A卷答案
- 基建工程设备管理员设备管理效益分析
- (完整版)新初一分班数学模拟真题经典
- 市场进入策略方案
- 2025云南昆明市惠筑建设开发有限公司招聘2人备考题库含答案详解(考试直接用)
- 江苏省无锡市江阴市六校2025-2026学年高一上学期期中联考语文试题(含答案)
- 无社保用工合同范本
- 中学班主任德育工作创新实践与案例
- 2026年浙江大学医学院附属妇产科医院公开招聘人员118人笔试考试参考试题及答案解析
- 2025江苏苏州市常熟经开控股有限公司(系统)招聘16人备考题库附答案解析
- 《篮球-原地单手肩上投篮》教学设计方案
- GB 14930.2-2025食品安全国家标准消毒剂
- 麦克斯韦方程组市公开课获奖课件
- 金坛区苏科版五年级上册劳动《11创意时钟(一)》课件
- 沥青路面施工旁站监理记录表多篇
评论
0/150
提交评论