Excel精英培训网

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

[已解决]请解释一段代码

[复制链接]
发表于 2014-3-4 11:36 | 显示全部楼层 |阅读模式
本帖最后由 ccq000000 于 2014-3-4 12:24 编辑

代码如下:
Private Sub ComboBox1_GotFocus()
   Dim arr, arr1()
   Dim k%, x%
   arr = Range("a1:a10")
   For x = 1 To UBound(arr)
      If arr(x, 1) > 10 Then
         k = k + 1
         ReDim Preserve arr1(1 To k, 1 To 1)
(此处出错,如定义arr1是一维的redim preserve arr1(1 to k)就能正常运行)
         arr1(k, 1) = arr(x, 1)
      End If
   Next x
   ComboBox1.List = arr1
End Sub
这是为什么?
2014-03-04_113416.png

最佳答案
2014-3-4 12:15
redim只能改变动态数组的末维。
ReDim Preserve arr1(1 To 1, 1 To k)
输出时,把arr1数组转置一下即可
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2014-3-4 11:46 | 显示全部楼层
ReDim Preserve arr1
只能重新定义后面的维数
回复

使用道具 举报

发表于 2014-3-4 11:47 | 显示全部楼层
本帖最后由 qcw811206 于 2014-3-4 11:48 编辑

可以用转置函数进行处理 Application.Transpose
回复

使用道具 举报

发表于 2014-3-4 12:15 | 显示全部楼层    本楼为最佳答案   
redim只能改变动态数组的末维。
ReDim Preserve arr1(1 To 1, 1 To k)
输出时,把arr1数组转置一下即可
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-17 12:43 , Processed in 0.272593 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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