【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 ...
随机推荐
- BZOJ 1711:[Usaco2007 Open]Dining吃饭(最大流)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1711 [题目大意] 每头牛都有一些喜欢的饮料和食物, 现在有一些食物和饮料,但是每样只 ...
- python基础之单例模式
单例模式: 什么是单例模式? 基于某种方法实例化多次得到实例是同一个 实现方法: ip = '1.1.1.1' port = 3306 # 假装来自配置文件 #方法一:定义类方法进行判断 class ...
- Spring的Bean生命周期理解
首先,在经历过很多次的面试之后,一直不能很好的叙述关于springbean的生命周期这个概念.今日对于springBean的生命周期进行一个总结. 一.springBean的生命周期: 如下图所示: ...
- Problem E: 调用函数,整数逆序输出
#include<stdio.h> int reverse(int number)//定义函数 { ;//result用于储存结果 ) { result=result*; i=number ...
- zabbix3.0的安装
Lamp环境搭建: #zabbix的版本,3.0之后的要求php版本5.4以上才支持 mysql需要对大小写敏感 编译安装PHP 下载 :wget http://mirrors.sohu.com/p ...
- 移动应用安全开发指南(Android)--Android组件和IPC
概述 移动应用开发中,往往有跨进程通信的需求,方便地实现程序间的数据共享.Android提供了多种IPC通信的方式,给开发人员带来了便利,但如果选择或使用不当,就有可能发生各种各样的风险. 安全准则 ...
- HMACSHA1算法的JAVA实现
import javax.crypto.Mac; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; publ ...
- PLM_百度百科
PLM_百度百科 ZDLINK
- 【RocketMQ】【分布式事务】使用RocketMQ实现分布式事务
参考地址:https://blog.csdn.net/zyw23zyw23/article/details/79070044 视频地址:https://v.youku.com/v_show/id_XO ...
- FIS的安装
FIS是专为解决前端开发中自动化工具.性能优化.模块化框架.开发规范.代码部署.开发流程等问题的前端工程化构建工具. 最重要的是,它是国产的!还是百度产的~~~亲切吧~~官网:http://fis.b ...