Excel精英培训网

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

[已解决](求助)如何批量提取数据?

[复制链接]
发表于 2012-9-8 15:25 | 显示全部楼层 |阅读模式
附件如右 批量提数附件.rar (39.45 KB, 下载次数: 24)
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2012-9-8 16:18 | 显示全部楼层    本楼为最佳答案   
  1. Sub test()
  2.     Dim arr, brr(), crr(1 To 50, 1 To 3), drr, d1, d2
  3.     Dim i As Long, j As Long, k As Long, x As Long, y As Long, irow As Long
  4.     Set d1 = CreateObject("scripting.dictionary")
  5.     Set d2 = CreateObject("scripting.dictionary")
  6.     irow = 29    '提定的行
  7.     For i = 2 To Worksheets.Count
  8.         With Sheets(i)
  9.             drr = .Cells(1, 1).Resize(50, 149)
  10.             arr = .Cells(irow, 1).Resize(1, 149)
  11.             d1.RemoveAll
  12.             d2.RemoveAll
  13.             Erase brr, crr
  14.             k = 0
  15.             For x = 51 To 99
  16.                 d1(arr(1, x)) = ""
  17.             Next
  18.             For x = 101 To 149
  19.                 d2(arr(1, x)) = ""
  20.             Next
  21.             For x = 1 To 49
  22.                 If d1.exists(arr(1, x)) And d2.exists(arr(1, x)) Then
  23.                     k = k + 1
  24.                     ReDim Preserve brr(1 To k)
  25.                     brr(k) = arr(1, x)
  26.                     If k = 3 Then Exit For
  27.                 End If
  28.             Next
  29.             For x = 1 To 3
  30.                 For y = x * 50 - 49 To x * 50 - 1
  31.                     If arr(1, y) = brr(x) Then
  32.                         For j = 1 To 50
  33.                             crr(j, x) = drr(j, y)
  34.                         Next
  35.                         Exit For
  36.                     End If
  37.                 Next
  38.             Next
  39.             .Cells(1, 151).Resize(50, 3) = crr
  40.         End With
  41.     Next
  42.     Set d1 = Nothing
  43.     Set d2 = Nothing
  44. End Sub
复制代码

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-7 00:05 , Processed in 0.257132 second(s), 17 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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