找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 484|回复: 0

[分享] 数组 集合 互转

[复制链接]

已领礼包: 604个

财富等级: 财运亨通

发表于 2016-11-18 10:59:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
  1. ' http://www.cnhup.com
  2. '================================
  3. 'VBA数组转换到集合CollectionToArray

  4. Public Function ArrayToCollection( _
  5.   arr As Variant, ByRef Coll As Collection) _
  6.   As Boolean
  7. Dim Ndx As Long
  8. Dim KeyVal As String

  9. If IsArray(arr) = False Then
  10.     ArrayToCollection = False
  11.     Exit Function
  12. End If

  13. On Error GoTo ErrH:
  14. Select Case NumberOfArrayDimensions(arr:=arr)
  15.     Case 0
  16.         ArrayToCollection = False
  17.         Exit Function
  18.         
  19.     Case 1
  20.         For Ndx = LBound(arr) To UBound(arr)
  21.             Coll.Add Item:=arr(Ndx)
  22.         Next Ndx
  23.    
  24.     Case 2
  25.         For Ndx = LBound(arr, 1) To UBound(arr, 1)
  26.             KeyVal = arr(Ndx, 1)
  27.             If Trim(KeyVal) = vbNullString Then
  28.                 Coll.Add Item:=arr(Ndx, 1)
  29.             Else
  30.                 Coll.Add Item:=arr(Ndx, 0), Key:=KeyVal
  31.             End If
  32.         Next Ndx
  33.    
  34.     Case Else
  35.         ArrayToCollection = False
  36.         Exit Function

  37. End Select

  38. ArrayToCollection = True
  39. Exit Function

  40. ErrH:
  41.     ArrayToCollection = False

  42. End Function

  43. '================================
  44. ' VBA集合转换到数组CollectionToArray
  45. '
  46. ' http://www.cnhup.com
  47. '================================

  48. Public Function CollectionToArray( _
  49.   Coll As Collection, arr As Variant) _
  50.   As Boolean
  51. Dim V As Variant
  52. Dim Ndx As Long

  53. If Coll Is Nothing Then
  54.     CollectionToArray = False
  55.     Exit Function
  56. End If

  57. If IsArray(arr) = False Then
  58.     CollectionToArray = False
  59.     Exit Function
  60. End If
  61. If IsArrayDynamic(arr:=arr) = False Then
  62.     CollectionToArray = False
  63.     Exit Function
  64. End If

  65. If Coll.Count < 1 Then
  66.     CollectionToArray = False
  67.     Exit Function
  68. End If
  69.    
  70. ReDim arr(1 To Coll.Count)

  71. For Ndx = 1 To Coll.Count
  72.     If IsObject(Coll(Ndx)) = True Then
  73.         Set arr(Ndx) = Coll(Ndx)
  74.     Else
  75.         arr(Ndx) = Coll(Ndx)
  76.     End If
  77. Next Ndx

  78. CollectionToArray = True

  79. End Function
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-23 20:33 , Processed in 0.169182 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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