ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 请问合并在不同分文件夹的同名同格式文件的程序怎么编写呢?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2012-8-29 22:49 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Please see if fit your request

从不同文件夹中汇总到一个EXCEL v4.rar

211.09 KB, 下载次数: 56

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-29 23:05 | 显示全部楼层
本帖最后由 sunnystar 于 2012-8-29 23:06 编辑
KCFONG 发表于 2012-8-29 22:49
Please see if fit your request

很赞啊!还实现了显示缺失值路径!
就是合并之后打开时还有原来的提示: “格式与文件扩展名指定的格式不一致”。是什么原因呢?因为合并好的数据可能会交给其他同事。
万分感谢!感谢您的及时帮助!我可以缓解出时间做更多有价值的事情了。

TA的精华主题

TA的得分主题

发表于 2012-8-29 23:11 | 显示全部楼层
Pleae test


Sub 合并()
Application.DisplayAlerts = False
Set fs = CreateObject("Scripting.FileSystemObject")
Set f = fs.GetFolder(ThisWorkbook.Path)
For Each ff In f.Files
  If ff.Name <> ThisWorkbook.Name Then
    Kill ff
  End If
Next ff
    Set sf = f.SubFolders
    For Each f1 In sf
       For Each fff In f1.Files
         If fff.Name Like "*.xls" Then
         nfilename = "合并" & Replace(fff.Name, "xls", "") & xlsx '合并filename
         Else
         nfilename = "合并" & fff.Name '合并filename
         End If
         nfile = ThisWorkbook.Path & "\" & nfilename '合并file fullname
            If fs.fileexists(nfile) = False Then
               Workbooks.Add
               Sheets(1).Name = "合并"
               ActiveWorkbook.SaveAs nfile
            Else
                 Workbooks.Open nfile
            End If
           
            Workbooks.Open fff  'source file
                er = [a65536].End(xlUp).Row
                ec = ActiveSheet.UsedRange.Columns.Count
                tr = Workbooks(nfilename).Sheets("合并").[b65536].End(xlUp).Row + 1 '合并filename
                If tr = 2 Then  'copy the title
                   tr = 1
                   ActiveSheet.Range(Cells(1, 1), Cells(1, ec)).Copy Workbooks(nfilename).Sheets("合并").Range("b1")
                   'Workbooks(nfilename).Sheets("合并").Range("a1") = fff
                End If
               
                tr = Workbooks(nfilename).Sheets("合并").[b65536].End(xlUp).Row + 1 '合并filename
                '数据缺失
                If er = 1 Then
                       Workbooks(nfilename).Sheets("合并").Range("a" & tr) = fff
                       Workbooks(nfilename).Sheets("合并").Range("b" & tr) = "数据缺失"
                Else
                      ActiveSheet.UsedRange.Copy Workbooks(nfilename).Sheets("合并").Range("b" & tr)
                      Workbooks(nfilename).Sheets("合并").Range("a" & tr & ":a" & tr + er - 1) = fff
                        Workbooks(nfilename).Sheets("合并").Rows(tr).Delete
                     
                End If
                ActiveWorkbook.Close False
                Workbooks(nfilename).Close True
       Next
    Next
  
Application.DisplayAlerts = True

End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-29 23:36 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 sunnystar 于 2012-8-29 23:43 编辑
KCFONG 发表于 2012-8-29 23:11
Pleae test

您写出的代码运行后,出现“运行时错误9 下标越界”   品牌1~5文件没有生成,品牌6、7生成好了
tr = Workbooks(nfilename).Sheets("合并").[b65536].End(xlUp).Row + 1 '合并filename
调试之后显示中后部位的这句有问题
语句.jpg

代码不懂,您有时间再做更改吧。
非常非常感谢您的帮助,晚安!

TA的精华主题

TA的得分主题

发表于 2012-8-29 23:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
上传你的档案

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-29 23:57 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
KCFONG 发表于 2012-8-29 23:47
上传你的档案

从不同文件夹中汇总到一个EXCEL v5.rar (273.8 KB, 下载次数: 9)
附件
我将您最新回复的代码粘贴进去运行,结果出现下标越界。
合并的结果也在此附件中。

我明白了出现问题上传附件。再次感谢!
时间晚了,您有时间再帮我抽空解答吧!晚安!太感谢您了!!!

TA的精华主题

TA的得分主题

发表于 2012-8-30 04:18 | 显示全部楼层
Please test

从不同文件夹中汇总到一个EXCEL v6.rar

210.94 KB, 下载次数: 117

评分

2

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-30 09:18 | 显示全部楼层
本帖最后由 sunnystar 于 2012-8-30 09:18 编辑
KCFONG 发表于 2012-8-30 04:18
Please test

感谢您这么早的回复。
今早到公司TEST了一下,完美实现!!!
太太太感谢您了!

TA的精华主题

TA的得分主题

发表于 2012-8-30 09:22 | 显示全部楼层
Don't tell your boss,
and seems work as past
种下菜 养下动物

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2012-8-31 20:20 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
KCFONG 发表于 2012-8-30 09:22
Don't tell your boss,
and seems work as past
种下菜 养下动物

是啊。;)
还可以多学点习。之前没时间提升水准。
这两天又忙的都没时间回复。下班又赶上断网。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-9 00:42 , Processed in 0.033542 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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