Excel精英培训网

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

[已解决]新学习vba的菜鸟,关于数组问题,求大侠相助

[复制链接]
发表于 2022-4-15 17:12 | 显示全部楼层 |阅读模式
1学分
本帖最后由 1049671600 于 2022-10-12 11:38 编辑

新学习vba的小菜鸟一个,今天在使用listview的时候,想把在listview勾选的数据重新存入到一个新的数组中,以供重新使用存入数组中数据的调用。
微信截图_20220415170536.png
能力有限,只能写出来点击存入后,先将数据写入excel表格中,再转存到数组中。
微信截图_20220415171052.png
能不能有更好的办法,能一键将勾选的数据直接循环到数组中。
最佳答案
2022-4-15 17:12
  1. Private Sub CommandButton6_Click()
  2. Dim br(1 To 10000, 1 To 3)
  3.     With ListView1
  4.         For i = 1 To .ListItems.Count
  5.             If .ListItems(i).Checked = True Then
  6.                 h = h + 1
  7.                 For j = 1 To 3
  8. '                   Cells(h + 1, j) = .ListItems(i).SubItems(j) '装入单元格内
  9.                    br(h, j) = .ListItems(i).SubItems(j)  '装入数组
  10.                 Next
  11.             End If
  12.         Next
  13.     End With
  14.     Sheet1.Range("a1").Resize(h, 3) = br
  15. End Sub
复制代码


test.rar

43.87 KB, 下载次数: 8

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2022-4-15 17:12 | 显示全部楼层    本楼为最佳答案   
  1. Private Sub CommandButton6_Click()
  2. Dim br(1 To 10000, 1 To 3)
  3.     With ListView1
  4.         For i = 1 To .ListItems.Count
  5.             If .ListItems(i).Checked = True Then
  6.                 h = h + 1
  7.                 For j = 1 To 3
  8. '                   Cells(h + 1, j) = .ListItems(i).SubItems(j) '装入单元格内
  9.                    br(h, j) = .ListItems(i).SubItems(j)  '装入数组
  10.                 Next
  11.             End If
  12.         Next
  13.     End With
  14.     Sheet1.Range("a1").Resize(h, 3) = br
  15. End Sub
复制代码


回复

使用道具 举报

 楼主| 发表于 2022-4-16 21:49 | 显示全部楼层
本帖最后由 1049671600 于 2022-4-16 21:55 编辑

非常感谢大虾的帮助。仿佛受到了很多新知识,茅塞顿开!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-25 23:33 , Processed in 0.294051 second(s), 7 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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