【VBA编程】10.自定义集合
自定义集合类型,类似于变量声明,只是要将Dim关键字和New collection关键字搭配起来使用,其语法描述如下:其中集合名的命名方式同于标准变量的命名
Dim 集合名 As New collection
对于已经定义的集合对象,可以使用集合的Add方法向集合中添加元素,语法如下:
集合名.add item[,key] [,before] [,after]
item:是一个必要的参数,表示将要添加到集合的对象名称
Key: 是一个可选参数,表示该对象在集合中以关键字表示,以供访问结合元素时,能够按照关键字访问
before:表示位于一个对象之前,其值为集合中某一对象的索引号
after:表示位于一个对象之后,其值为集合中某一对象的索引号
【环境准备】
首先插入“类模块”

修改“类模块”名称

双击修改后的“类模块”名称,并在代码窗口写下如下代码:

然后,新建插入“模块”
【代码区域】
Sub 自定义集合()
Dim zdyjh As New Collection '自定义一个集合
Dim obj As classname '定义一个对象
Dim num As Integer '定义一个计数器
Set obj = New classname '对一个变量赋值
obj.name = "杨过" '为对象的属性赋值
zdyjh.Add Item:=obj, Key:="first" '将对象添加到集合中
Set obj = New classname '新建一个对象
obj.name = "郭靖"
zdyjh.Add Item:=obj, Key:="second"
Set obj = New classname
obj.name = "黄蓉"
zdyjh.Add Item:=obj, Key:="third"
For i = To
Debug.Print
Next
'输出现有集合中的元素
Debug.Print "现有集合中共有" & CStr(zdyjh.Count) & "个元素,个元素举例如下:"
Debug.Print
num =
For Each tempobj In zdyjh
Debug.Print "第" & CStr(num) & "对象名字为:" & tempobj.name 'CStr函数将数据强制转换为字符
Debug.Print
num = num +
Next
Set obj = New classname
obj.name = "段誉"
zdyjh.Add Item:=obj, Key:="forth", before:=
Debug.Print "在第2个对象之前插入对象后,集合中共有" & CStr(zdyjh.Count) & "个元素,各元素列举如下:"
Debug.Print
num =
For Each tempobj In zdyjh
Debug.Print "第" & CStr(num) & "对象的名字为:" & tempobj.name
Debug.Print
num = num +
Next
Set obj = New classname
obj.name = "胡八一"
zdyjh.Add Item:=obj, Key:="five", after:=
Debug.Print "在第三个对象之后插入对象后,集合共有" & CStr(zdyjh.Count) & "个元素,各元素列举如下:"
Debug.Print
num =
For Each tempobj In zdyjh
Debug.Print "第" & CStr(num) & "对象的名字为:" & tempobj.name
Debug.Print
num = num +
Next
'移除第三个对象
zdyjh.Remove ()
Debug.Print "删除第三个对象之后,集合共有" & CStr(zdyjh.Count) & "个元素,各元素列举如下:"
Debug.Print
num =
For Each tempobj In zdyjh
Debug.Print "第" & CStr(num) & "对象的名字为:" & tempobj.name
Debug.Print
num = num +
Next
End Sub
【结果展示】
立即窗口打印结果为:
|
现有集合中共有3个元素,个元素举例如下: 第1对象名字为:杨过 第2对象名字为:郭靖 第3对象名字为:黄蓉 在第2个对象之前插入对象后,集合中共有4个元素,各元素列举如下: 第1对象的名字为:杨过 第2对象的名字为:段誉 第3对象的名字为:郭靖 第4对象的名字为:黄蓉 在第三个对象之后插入对象后,集合共有5个元素,各元素列举如下: 第1对象的名字为:杨过 第2对象的名字为:段誉 第3对象的名字为:郭靖 第4对象的名字为:胡八一 第5对象的名字为:黄蓉 删除第三个对象之后,集合共有4个元素,各元素列举如下: 第1对象的名字为:杨过 第2对象的名字为:段誉 第3对象的名字为:胡八一 第4对象的名字为:黄蓉 |
【VBA编程】10.自定义集合的更多相关文章
- C#高级编程(第9版) 第10章 集合 笔记
话说 虽然敲过好多代码, 但除了C++,一直没正眼瞧过其它语言.(没办法 谁叫C++既有oop又能自由控制内存呢) 今天 看公司老项目的src,c#的,linq+Dictionary的用法有感.所以找 ...
- VBA编程的工程性规划
看过很多人写的VBA代码,一团一团的,一点规划都没有,为了VBA编程更具工程性,这里讨论一下,并列出自己的一些建议:0.给VBA工程定义一个名字,而非直接使用默认的名称——"VBAProje ...
- vba编程基础2
安装office2010的时候, 最好是 完全安装/完整安装 , 这样可以查阅 excel的 "帮助文档" 帮助文档中包含了更多的/更详细的 参考信息. 普通模块无事件, 只有 子 ...
- vba编程基础1
在主要的编程语言中, 结构体是用大括号来表示 代码段的 范围 界定的. 但是在一些比较"老的"语言中,由于历史原因, 还是使用的 是: 关键字来进行界定代码 的 结构段, 如vba ...
- VBA编程常用词汇英汉对照表
表 20‑1到表 20‑8是VBA编程中使用频率最高的英文单词,按字母排序.词性列中,a表示形容词,n表示名词,v表示动词,p表示介词以及其他词性. 表 20‑1 VBA编程常用词汇表 单词 中文 词 ...
- 《C#本质论》读书笔记(16)构建自定义集合
16.1 更多集合接口 集合类(这里指IEnumerable层次结构)实现的接口层次结构 16.1.1 IList<T>与IDictionary<TKey,TValue> 字典 ...
- UICollectionView(集合视图)以及自定义集合视图
一.UICollectionView集合视图 其继承自UIScrollView. UICollectionView类是iOS6新引进的API,用于展示集合视图,布局 ...
- 集合、拆箱、装箱、自定义集合的foreach
集合部分 参考:http://msdn.microsoft.com/zh-cn/library/0ytkdh4s(v=vs.110).aspx 集合类型是诸如哈希表.队列.堆栈.包.字典和列表等数据集 ...
- 十六、C# 常用集合类及构建自定义集合(使用迭代器)
常用集合类及构建自定义集合 1.更多集合接口:IList<T>.IDictionary<TKey,TValue>.IComparable<T>.ICollectio ...
随机推荐
- mvc4 to mvc5 orEF5 to EF6 ,(升级EF6)
把后台MVC4 自动生成的网站从EF5.0 升级为 EF6.1.3 (6.0以上) 报错 找不到方法:“System.Data.Objects.ObjectContext System.Data.En ...
- 【BZOJ 1455】 1455: 罗马游戏 (可并堆-左偏树+并查集)
1455: 罗马游戏 Description 罗马皇帝很喜欢玩杀人游戏. 他的军队里面有n个人,每个人都是一个独立的团.最近举行了一次平面几何测试,每个人都得到了一个分数. 皇帝很喜欢平面几何,他对那 ...
- 【BZOJ 1084】 1084: [SCOI2005]最大子矩阵 (DP)
1084: [SCOI2005]最大子矩阵 Description 这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大.注意:选出的k个子矩阵不能相互重叠. Input 第 ...
- JZYZOJ1539[haoi2015]T2 树链剖分
http://172.20.6.3/Problem_Show.asp?id=1539 在学校的OJ又写了一次,RE了好多次,原来haoi的时候这道题需要开栈+快读,裸数据结构30分,加上快读50分.o ...
- BZOJ 1131 [POI2008]Sta(树形DP)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1131 [题目大意] 给出一个N个点的树,找出一个点来,以这个点为根的树时,所有点的深度 ...
- 【动态规划】POJ3280- Cheapest Palindrome
[题目大意] 给出一个字符串,可以删除或添加一些字符,它们各自会消耗价值.问最少消耗多少价值,可以使得字符串变成回文的. [思路] 事实上删除或添加字符的价值只需要保持较小的那一个.假设当前要将(j, ...
- Linux命令之sync - 强制将内存中的文件缓冲内容写到磁盘
转:http://www.linuxso.com/command/sync.html sync命令 linux同步数据命令 格式: sync 用途:更新 i-node 表,并将缓冲文件写到硬盘中. 功 ...
- 诡异的 "密码取回" 邮件问题
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Redis-NoSql 概述,NoSql的优点
全称 not only sql: 全新数据库理念:非关系型数据库: 高并发读写:海量数据的高效率存储和访问:高可扩展性和高可用性: 键值对存储:列存储:文档数据库:图形数据库: 易扩展:灵活的数据模型 ...
- 【mysql】mysql增加version字段实现乐观锁,实现高并发下的订单库存的并发控制,通过开启多线程同时处理模拟多个请求同时到达的情况 + 同一事务中使用多个乐观锁的情况处理
mysql增加version字段实现乐观锁,实现高并发下的订单库存的并发控制,通过开启多线程同时处理模拟多个请求同时到达的情况 ==================================== ...