Excel精英培训网

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

[已解决]按条件提取不同的。

[复制链接]
发表于 2014-11-22 20:56 | 显示全部楼层 |阅读模式
本帖最后由 left369 于 2014-11-22 22:23 编辑

按条件提取不同的。
最佳答案
2014-11-22 21:38
  1. Sub Macro1()
  2. Dim arr, brr, i&, j%, p$$, s%
  3. arr = Range("b17").CurrentRegion
  4. ReDim brr(1 To 10, 1 To UBound(arr, 2))
  5. For j = 1 To UBound(arr, 2)
  6.     p = "": s = 0
  7.     For i = UBound(arr) To 1 Step -1
  8.         If InStr(p, arr(i, j)) = 0 Then
  9.             s = s + 1
  10.             brr(s, j) = arr(i, j)
  11.             p = p & arr(i, j)
  12.         End If
  13.     Next
  14. Next
  15. Range("b52").Resize(10, UBound(brr, 2)) = brr
  16. End Sub
复制代码

文件.zip

8.73 KB, 下载次数: 24

发表于 2014-11-22 21:38 | 显示全部楼层    本楼为最佳答案   
  1. Sub Macro1()
  2. Dim arr, brr, i&, j%, p$$, s%
  3. arr = Range("b17").CurrentRegion
  4. ReDim brr(1 To 10, 1 To UBound(arr, 2))
  5. For j = 1 To UBound(arr, 2)
  6.     p = "": s = 0
  7.     For i = UBound(arr) To 1 Step -1
  8.         If InStr(p, arr(i, j)) = 0 Then
  9.             s = s + 1
  10.             brr(s, j) = arr(i, j)
  11.             p = p & arr(i, j)
  12.         End If
  13.     Next
  14. Next
  15. Range("b52").Resize(10, UBound(brr, 2)) = brr
  16. End Sub
复制代码
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-8 09:07 , Processed in 0.328115 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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