Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 2007|回复: 3

[已解决]VBA提取信息

[复制链接]
发表于 2013-6-7 20:42 | 显示全部楼层 |阅读模式
遍历指定文件夹下的所有工作簿,将各工作簿中命名为“提成表”的信息复制粘贴到“汇总”表中,需求详见附件。
最佳答案
2013-6-7 22:15
  1. Sub 汇总()
  2.     Application.ScreenUpdating = False
  3.     Dim lj As String
  4.     Dim dirname As String
  5.     Dim nm As String
  6.     Dim i As Integer
  7.     lj = ActiveWorkbook.Path    '激活工作簿路径
  8.     nm = ActiveWorkbook.Name  '激活工作簿名称
  9.     dirname = Dir(lj & "\*.xls*")    '用DIR取得工作表名
  10.     Cells.Clear              '删除数据
  11.     Do While dirname <> ""   '工作簿名<>空,就循环
  12.         If dirname <> nm Then  '如果工作表簿<>激活工作簿名
  13.             Workbooks.Open Filename:=lj & "" & dirname  '打开DIR找到的工作簿
  14.             i = Workbooks(dirname).Sheets("提成表").Range("A65536").End(xlUp).Row
  15.             Sheets("提成表").Activate
  16.             Workbooks(nm).Activate
  17.             Workbooks(dirname).Sheets("提成表").Range("A1:W" & i).Copy Range("A65536").End(xlUp).Offset(2, 0)
  18.             Workbooks(dirname).Close False   '关闭工作簿不保存修改
  19.         End If
  20.         dirname = Dir
  21.     Loop
  22.     Application.ScreenUpdating = True
  23. End Sub
复制代码

汇总.zip

53.39 KB, 下载次数: 23

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2013-6-7 20:49 | 显示全部楼层
回复

使用道具 举报

发表于 2013-6-7 22:02 | 显示全部楼层
本帖最后由 开心妙妙 于 2013-6-7 22:18 编辑

汇总.zip (95.94 KB, 下载次数: 19)
回复

使用道具 举报

发表于 2013-6-7 22:15 | 显示全部楼层    本楼为最佳答案   
  1. Sub 汇总()
  2.     Application.ScreenUpdating = False
  3.     Dim lj As String
  4.     Dim dirname As String
  5.     Dim nm As String
  6.     Dim i As Integer
  7.     lj = ActiveWorkbook.Path    '激活工作簿路径
  8.     nm = ActiveWorkbook.Name  '激活工作簿名称
  9.     dirname = Dir(lj & "\*.xls*")    '用DIR取得工作表名
  10.     Cells.Clear              '删除数据
  11.     Do While dirname <> ""   '工作簿名<>空,就循环
  12.         If dirname <> nm Then  '如果工作表簿<>激活工作簿名
  13.             Workbooks.Open Filename:=lj & "" & dirname  '打开DIR找到的工作簿
  14.             i = Workbooks(dirname).Sheets("提成表").Range("A65536").End(xlUp).Row
  15.             Sheets("提成表").Activate
  16.             Workbooks(nm).Activate
  17.             Workbooks(dirname).Sheets("提成表").Range("A1:W" & i).Copy Range("A65536").End(xlUp).Offset(2, 0)
  18.             Workbooks(dirname).Close False   '关闭工作簿不保存修改
  19.         End If
  20.         dirname = Dir
  21.     Loop
  22.     Application.ScreenUpdating = True
  23. End Sub
复制代码

评分

参与人数 1 +12 收起 理由
as0810114 + 12 很给力!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-30 14:30 , Processed in 0.392217 second(s), 14 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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