前景提要(文末提供源码下载)

相信现在很多的小伙伴们都有接触过Python,在学习Python的时候,我们都学到了列表和集合,Python中的集合有一个特性,就是数据不重复,有点类似Excel中的字典,那么Excel中是否存在这样的一个集合的概念呢?

其实Excel VBA中也是有这样的一个概念的,应该也是叫做集合,在集合中的数据必须保证唯一,那么我们也可以利用集合的这个特性来获取数据的唯一值,来看看如何操作。

场景说明

还是我们昨天使用过的工作表的样式,我们今天尝试通过其他的方式来获取工作表某列的唯一值,我们来获取性名列的唯一值,再之前我们学习了通过RemoveDuplicates和AdvancedFilter方法来实现,现在我们尝试通过集合的方式来实现这样的效果。

代码区

Sub jihe()On Error Resume NextDim ExcelSet As New CollectionFor i = 2 To 23 ExcelSet.Add Cells(i, 1), Cells(i, 1).TextNext iFor i = 1 To ExcelSet.Count  Cells(i + 1, 5) = ExcelSet.Item(i) NextEnd Sub

代码依然是非常的简短,代码解析的时候,我们会详细讲解下Excel集合的用法,这里我们来看看效果如何

通过上面的动图和最终的筛选之后的结果来进行对比,证明我们的数据结果是没有任何的问题的。

代码解析

来看看今天的代码是如何实现的,我们这里要学习一个集合的概念,在Excel中也有一个集合的概念,就是Collection

但是他并不能够直接使用,我们需要现声明,这个和大家熟悉的字典之类的是一样的方式

Dim ExcelSet As New Collection

这就是申明的方式,非常的简单

然后我们就可以效仿字典的方式,通过循环的结构往集合中添加数据,和字典一样,集合的值也只能存在唯一一个

所以在最开始我们需要先进行错误处理

On Error Resume Next

如果添加了相同的值,那么肯定会报错的,所以要忽略错误内容,跳过继续添加下面的数据,最终一个循环结束之后,我们就得到了整个集合

如果你允许展开的话,你会发现对应的每一个item的值就是某一个姓名,比方说我们展开item5

得到了整个集合之后呢,我们就可以将集合的内容遍历输出,得到我们想要的结果了。

输出的时候我们这里采用循环遍历的方式,为什么不想字典一样采用直接得到item的全部,一次性输出呢?

因为集合并不存在这样的概念。

所以这也是集合的知名度低于字典的原因吧,要想输出结果,只能通过遍历循环的方式来实现。

================================

本节课的案例源码已经上传,需要的小伙伴请按照如下步骤操作,一个不能少哦~~

1.转发下本文章(算是对我的小小支持吧~)

2.后台私信“8-4”

希望大家多支持~~,多多关注 ~ ~

好了,明晚19:00,准时再见!

循环结果添加到集合_Excel VBA 8.4 Python中有集合直接获取唯一值,那Exce中可以吗?...相关推荐

  1. python执行系统命令后获取返回值的几种方式集合

    第一种情况 os.system('ps aux') 执行系统命令,没有返回值 第二种情况 result = os.popen('ps aux') res = result.read() for lin ...

  2. 使用VBA调用jar传递参数,并获取返回值

    目录 ■VBA代码 ■Java代码 ■运行效果 Excel Log效果 (通过VBA调用jar后,运行,生成的Log) ■课题 ■课题原因(直接原因) ●log4j的配置 ■课题验证 ■课题解决(其他 ...

  3. 循环结果添加到集合_Java Note-数据结构(4)集合

    集合Set 确定性:对任何对象都能判定其是否属于某一个集合: 互异性:集合内每个元素都是不相同的,内容互异: 无序性:集合内的顺序无关: Java中的集合接口Set HashSet(基于散列函数的集合 ...

  4. vba mysql·教程_Excel VBA ADO SQL入门教程004:SQL中的Excel表

    1. 上期我们聊了SQL常用查询语句中的字段查询,其简化版语法如下: SELECT 字段名 FROM 表名 当时我们说,FROM关键词指明了要获取字段信息的表的名称.倘若数据源是Excel表格,则需要 ...

  5. find vba 模糊_EXCEL——VBA实现模糊查找并获取查找到的单元格内容

    image 大家有没有遇到过这种情况,要在一张数据很多的sheet中进行查找匹配一个数据或多个数据(部分匹配),并对查找到的单元格内容进行汇总.这个时候如果对多个数据一个个在目标sheet中ctrl ...

  6. vba遍历数组_Excel VBA中如何对数组进行去重

    在使用Excel VBA的过程中,经常需要使用数组(Array)将数据进行存放,但防止数据出现重复成文了一个问题.这是就可以用到对数组进行去重. 现在我们有一个数组分别是a 这个数组中有部分重复数值, ...

  7. Vue用v-for给循环标签添加属性

    Vue用v-for给循环标签添加属性 用单向数据绑定v-bind:style 简写方式,在属性名前加冒号 <p class="song-lyric-item" v-for=& ...

  8. 递归——函数在内部自己调用自己,那么该函数是递归函数 作用和循环效果一样 要加推出条件return,否则发生栈溢出,导致死循环 递归给数组中对象添加属性 toString()和随机数

    递归--函数在内部自己调用自己,那么该函数是递归函数 & 作用和循环效果一样 & 要加推出条件return,否则发生栈溢出,导致死循环 & 递归给数组中对象添加属性 & ...

  9. 微信小程序for循环里面添加input事件

    1,在微信小程序for循环里面添加input事件,并把input输入值添加到列表里面 2.wxml <view class="item" wx:for="{{lis ...

  10. vba移动文件_Excel VBA 之 按需求移动、复制文件

    今天接到一个需求,用VBA将一个文件夹内的文件分配到不同的文件夹中,我用了几行代码就解决了,现在我来分享给大家. 现在,文件夹内有一些文件,如图: 我们可以根据自己的需求在Excel表格里将文件结构编 ...

最新文章

  1. Oracle函数大全2
  2. 【转】visual studio 2010失败或.net framework 4.0 0xc8000247错误解决
  3. BugkuCTF-Crypto题进制转换
  4. 如何关闭rsyslog服务?_Linux日志服务器设置过程
  5. android listview 分析,android中ListView的定位:使用setSelectionFromTop
  6. webpack 4 入门教程一
  7. 不小心执行了rm-rf,除了跑路,如何恢复?
  8. [luogu3198] 玩具装箱
  9. 与代数式xyz所对应的C语言表达式是,C程序习题集讲解.doc
  10. 多层次细节(Level of detail)
  11. 交换机的主要功能和工作特性
  12. QuatusII--7段数码管
  13. 苹果公司的创始人_世界名校巡礼15——苹果公司创始人的母校加州大学伯克利分校...
  14. MTK平台的srvcc相关故障
  15. 自2018年2月28日起 iCloud 由云上贵州运营
  16. 9.2 常用缩写汇总表
  17. Vue结合element-ui实现导航菜单展开收缩小功能
  18. 东财《消费者行为学X》综合作业
  19. 如何优化网站关键词?
  20. Error querying database. Cause: java.sql.SQLSyntaxErrorException

热门文章

  1. 终于来了,超详细手眼标定原理与实战视频教程
  2. 小Q正在给一条长度为n的道路设计路灯安置方案。 为了让问题更简单,小Q把道路视为n个方格,需要照亮的地方用'.'表示, 不需要照亮的障碍物格子用'X'表示。
  3. 【日本软件外包】设计书中常用到的文型
  4. 深入web的请求过程
  5. 两个用于win7任务栏显示进度的dll
  6. Java jsp 自定义标签
  7. hdu--1073--字符串处理
  8. easyui小清新俺也晒晒 视频管理软件bs项目
  9. Java程序员必读——领悟Java编程思想
  10. 从零基础入门Tensorflow2.0 ----九、44.1 keras 保存模型、参数