Excel精英培训网

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

[已解决]用VBA的方法提取所需的数。

[复制链接]
发表于 2012-1-8 21:47 | 显示全部楼层 |阅读模式
用VBA的方法提取所需的数。
最佳答案
2012-1-8 22:19
本帖最后由 sunjing-zxl 于 2012-1-8 22:20 编辑
  1. Sub aa()
  2.     Dim arr, arr1
  3.     Dim i As Long, j As Long
  4.     Range(Cells(1, 2), Cells(65536, "IV")).ClearContents
  5.     arr = Range("A1:A" & [A65536].End(xlUp).Row)
  6.     ReDim arr1(1 To 50, 1 To Int(UBound(arr) / 2) + 1)
  7.     For i = 1 To UBound(arr1, 2)
  8.         For j = 1 To UBound(arr1)
  9.             If i + j * (i - 1) > UBound(arr) Then
  10.                 Exit For
  11.             Else
  12.                 arr1(j, i) = arr(i + j * (i - 1), 1)
  13.             End If
  14.         Next j
  15.     Next i
  16.     Range("B1").Resize(UBound(arr1), UBound(arr1, 2)) = arr1
  17. End Sub
复制代码
附件: TT-sunjing.rar (11.9 KB, 下载次数: 17)

aaaa.rar

7.88 KB, 下载次数: 8

 楼主| 发表于 2012-1-8 21:48 | 显示全部楼层
本帖最后由 tting 于 2012-1-8 21:48 编辑

考虑到当有几千行时,可能运行慢。
可以将结果规定为列显示600列、行50行(最多间隔50格)

回复

使用道具 举报

发表于 2012-1-8 22:19 | 显示全部楼层    本楼为最佳答案   
本帖最后由 sunjing-zxl 于 2012-1-8 22:20 编辑
  1. Sub aa()
  2.     Dim arr, arr1
  3.     Dim i As Long, j As Long
  4.     Range(Cells(1, 2), Cells(65536, "IV")).ClearContents
  5.     arr = Range("A1:A" & [A65536].End(xlUp).Row)
  6.     ReDim arr1(1 To 50, 1 To Int(UBound(arr) / 2) + 1)
  7.     For i = 1 To UBound(arr1, 2)
  8.         For j = 1 To UBound(arr1)
  9.             If i + j * (i - 1) > UBound(arr) Then
  10.                 Exit For
  11.             Else
  12.                 arr1(j, i) = arr(i + j * (i - 1), 1)
  13.             End If
  14.         Next j
  15.     Next i
  16.     Range("B1").Resize(UBound(arr1), UBound(arr1, 2)) = arr1
  17. End Sub
复制代码
附件: TT-sunjing.rar (11.9 KB, 下载次数: 17)
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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