Excel精英培训网

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

[已解决]对称,相同提取。

[复制链接]
发表于 2014-4-27 09:19 | 显示全部楼层 |阅读模式
本帖最后由 left369 于 2014-4-27 11:55 编辑

对称,相同提取。麻烦见附件,谢谢。
最佳答案
2014-4-27 11:40
  1. Sub Macro1()
  2. Dim arr, brr, i&, j%, s&, y&, x&
  3. arr = Range("b33").CurrentRegion
  4. x = UBound(arr)
  5. ReDim brr(1 To x, 1 To UBound(arr, 2) - 1)
  6. For i = x To 1 Step -1
  7.     s = x + 1 - i: y = i - s
  8.     If y < 1 Then Exit For
  9.     For j = 2 To UBound(arr, 2)
  10.         If arr(i, j) = arr(y, j) Then brr(s, j - 1) = arr(i, j)
  11.     Next
  12. Next
  13. Cells(x + 36, 2).Resize(s, UBound(brr, 2)) = brr
  14. End Sub
复制代码

对称相同提取.zip

61.55 KB, 下载次数: 24

发表于 2014-4-27 09:33 | 显示全部楼层
你检查下你的求助有没有问题,咱看不出规律来!
回复

使用道具 举报

发表于 2014-4-27 11:40 | 显示全部楼层    本楼为最佳答案   
  1. Sub Macro1()
  2. Dim arr, brr, i&, j%, s&, y&, x&
  3. arr = Range("b33").CurrentRegion
  4. x = UBound(arr)
  5. ReDim brr(1 To x, 1 To UBound(arr, 2) - 1)
  6. For i = x To 1 Step -1
  7.     s = x + 1 - i: y = i - s
  8.     If y < 1 Then Exit For
  9.     For j = 2 To UBound(arr, 2)
  10.         If arr(i, j) = arr(y, j) Then brr(s, j - 1) = arr(i, j)
  11.     Next
  12. Next
  13. Cells(x + 36, 2).Resize(s, UBound(brr, 2)) = brr
  14. End Sub
复制代码
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-20 19:01 , Processed in 0.286255 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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