ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

合并多个工作簿的同名工作表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-10-31 18:41 | 显示全部楼层 |阅读模式
请教一下各位大神,怎么用vba实现将同一文件夹中多个工作簿的指定名称的同名工作表进行合并汇总,粘贴方式为贴值和格式。

类似于如下链接的操作。但有两点需要调整一下:1、不用打开所有工作簿;2、粘贴方式为贴值和格式。



宏Excel合并多个具有相同工作表名称的工作簿_导入Excel工作簿的多个工作表_将具有特定名称的Excel工作表从多个工作簿复制到新工作簿 - 腾讯云开发者社区 - 腾讯云


谢谢各位大神了!!

TA的精华主题

TA的得分主题

发表于 2024-10-31 19:01 | 显示全部楼层
这么懒吗?求助了附件都不上传一个

TA的精华主题

TA的得分主题

发表于 2024-10-31 19:34 | 显示全部楼层
这样的求助我想没有人会解答。

TA的精华主题

TA的得分主题

发表于 2024-11-1 08:38 | 显示全部楼层
没有放之四海而皆准的代码,再高明的代码都得根据表格结构等情况来写的,所以,要得到完美的答案,最好还是上传你自己的附件

TA的精华主题

TA的得分主题

发表于 2024-11-12 16:05 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
根据附件,自行修改,基本就是放哪儿都能用

5_多工作簿指定工作表,全部数据汇总.rar

66.55 KB, 下载次数: 18

TA的精华主题

TA的得分主题

发表于 2024-11-14 11:27 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Sub test()
Dim f, filename As String
Dim fu(1 To 5)
Dim k, x, i, j As Integer
Dim wb As Workbook
Dim sh As Worksheet
Dim arr

On Error Resume Next
f = ThisWorkbook.Path & "\" '获得文件下需要汇总文件的名称
filename = Dir(f & "*.xlsx")
Do
            k = k + 1
        fu(k) = filename
    filename = Dir
Loop Until filename = ""


For x = 1 To UBound(fu)
    If Len(fu(x)) > 3 Then
        Set wb = Workbooks.Open(f & fu(x))
    End If
    For i = 1 To wb.Sheets.Count
        j = ThisWorkbook.Sheets("汇总").Range("c65536").End(xlUp).Row + 1
        ThisWorkbook.Sheets("汇总").Range("a" & j) = Left(wb.Name, 3)
        ThisWorkbook.Sheets("汇总").Range("b" & j) = wb.Sheets(i).Name
        wb.Sheets(i).UsedRange.Offset(1, 0).Copy ThisWorkbook.Sheets("汇总").Range("c" & j)
    Next i
    wb.Close True
Next x

k = Range("c65536").End(xlUp).Row
arr = Range("a4:b" & k)
For x = 1 To UBound(arr)
    If arr(x + 1, 1) = "" Then
        arr(x + 1, 1) = arr(x, 1)
    End If
    If arr(x + 1, 2) = "" Then
        arr(x + 1, 2) = arr(x, 2)
    End If
Next x
Range("a4").Resize(UBound(arr), 2) = arr
End Sub
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-23 16:04 , Processed in 0.045516 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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