最近写了一些小功能,对字典有了进一步的理解,太强大了!

个人最近用过的字典应用有这么几个,写下来防止自己忘~同时方便大家

一、查找重复行

【原理】利用字典的exist方法,将数据加入字典时判断一下,如果已经存在,就说明当前数据为重复数据,应该删除

【示例代码】

Sub chongfu()         '查重
Dim i As Long
Dim endline As Long '定义工作表长度变量
endline = Sheet3.Range("A30000").End(xlUp).Row '获取工作表Sheet3有数据的最后一行行号
Set d = CreateObject("scripting.dictionary") '设定字典d
For i = endline To Step - '从最后一行开始,依次把各个字段拼接到一起(注意,这里我的需求是这几个字段拼在一起的字符串不允许重复,因此我先拼接再判重)
'把所有字符串拼接到数组里
If Sheet3.Cells(i, ) <> "" Then '判断该行是否为空
If IsError(Sheet3.Cells(i, )) = False Then '如果关键单元格不是#N/A,则进入字典设置
x = Sheet3.Cells(i, ) '******************设置赋给字典的变量,即需要去重的单元格!*******************
If Not d.Exists(x) Then '判断是否重复
d(x) = x '如果不重复,则把x定为item
Else
Sheet3.Rows(i & ":" & i).Delete Shift:=xlUp '如果字典中已有对应的item,则该行重复,删除重复的行
End If
End If
End If
Next
End Sub

【效果展示】

二、查找关键字

【原理】最常见的应用,根据key来查找对应的item

【示例代码】

Sub DicFind()       '查找编号对应的数据
endline = Sheet3.Range("E100000").End(xlUp).Row '获取待匹配的数据区域长度
Set d = CreateObject("Scripting.Dictionary") '设置字典d
Arr = Sheet3.Range("A2:B26975") '获得字典数据
For i = To UBound(Arr) '设置sheet3 A列为字典关键字key,B列为字典关键字对应的值(item)
If Arr(i, ) <> "" Then '当A列不为空时,将item装入数组
x = Arr(i, ) '想以哪一列为关键字查找结果,就把x设置成哪一列的单元格
d(x) = Arr(i, )
Else
Exit For 'A列为空时,退出for循环
End If
Next
Brr = Sheet3.Range("$E$2:$F$" & endline) '将待查找的数据放入数组
For j = To UBound(Brr)
x = Brr(j, ) '将E列的编号设为key
If d.Exists(x) Then '如果字典中有对应的item,则将item写入数组brr
Brr(j, ) = d(x) '把查找到的item写入brr,这里对应F列
End If
Next
Sheet3.Range("$E$2:$F$" & endline) = Brr '将匹配好的数据写回单元格
End Sub

【效果展示】

建设中。。。。。。之后想起来就更新~

写了一半,发现早就有完善的教程了(汗)

作者是ExcelHome 的ExcelVBA程序开发区的版主 蓝桥玄霜,特此注明

http://club.excelhome.net/thread-868892-1-1.html

Excel VBA ——字典实用技巧的更多相关文章

  1. Excel VBA入门(二)数组和字典

    数组和字典也是VBA的常用到数据类型之一.但是我翻了有四五本VBA教程相关的书,里面都没有介绍到字典,数组到是在介绍数据类型时有介绍,而并没有提到字典. 事实上,字典不是VBA内置的类型,它是Wind ...

  2. Excel实用技巧-如何批量提取excel工作表名称

    Excel实用技巧-如何批量提取excel工作表名称 1. 打开Excel文件,点击“公式”栏,进而点击“定义管理器” 2. 在弹出的对话框中,点击新增按钮, 名称:“sheet”,引用位置:“=RE ...

  3. 在Excel VBA中使用SQL到底优势在哪儿

    小爬在之前的博文中多次提到,可以在VBA中写SQL来操作Excel文件,实现各类数据处理和分析需求.那么,你可能有这样的疑问:Excel原生的VBA,数据透视表,数据分析功能不够吗,为啥一定要用SQL ...

  4. iOS开发实用技巧—Objective-C中的各种遍历(迭代)方式

    iOS开发实用技巧—Objective-C中的各种遍历(迭代)方式 说明: 1)该文简短介绍在iOS开发中遍历字典.数组和集合的几种常见方式. 2)该文对应的代码可以在下面的地址获得:https:// ...

  5. 使用Excel VBA编程将网点的百度坐标转换后标注到高德地图上

    公司网点表存储的坐标是百度坐标,现需要将网点位置标注到高德地图上,研究了一下高德地图的云图数据模版 http://lbs.amap.com/yuntu/reference/cloudstorage和坐 ...

  6. Excel VBA(宏):添加宏

    写在前面: .编写宏,打开VBA,双击ThisWorkbook对当前工作薄进行编写宏:双击Sheet1,对整个sheet编写宏: 或者创建模块,在模块里,编写.调试代码. 打开VBA的方法见第一讲,结 ...

  7. JavaScript函数作用域与对象以及实用技巧

    1. JS作用域 1.1 全局作用域和局部作用域 函数外面声明的就是 全局作用域 函数内是局部作用域 全局变量可以直接在函数内修改和使用 变量,使用var是声明,没有var是使用变量. 如果在函数内使 ...

  8. Excel VBA 操作 Word(入门篇)

    原文地址 本文的对象是:有一定Excel VBA基础,对Word VBA还没有什么认识,想在Excel中通过VBA操作Word还有困难的人.   一.新建Word引用 需要首先创建一个对 Word A ...

  9. Excel VBA入门(九)操作工作薄

    虽然我前面讲过,在VBA中操作工作薄并不是件明智的事,但有些时候,还是避免不了要这么做.绝大多数情况下,我们要做的是获取到某个工作薄对象,并以此来获得其中的工作表对象,然后再对工作表中的数据进行处理. ...

随机推荐

  1. 微软MSDN原版Windows Server 2008 R2 With SP1下载

    Windows Server 2008 R2是windows 服务器版本Windows Server 2008 R2继续提升了虚拟化.系统管理弹性.网络存取方式,以及信息安全等领域的应用,其中有不少功 ...

  2. C#中List按特定字段排序

    有一个类,如Student,有学号.数学成绩.语文成绩, 存在List列表中,要将List按数学成绩排序,怎么办呢? List<Student> scores=GetScores(); s ...

  3. php7带来的性能升级

    前言本文是一篇讲座听后+后续研究的总结. 话说当年追时髦,php7一出就给电脑立马装上了,php5和php7共存,也是立马写了个超级耗时间的循环脚本测了一番,确实php7给力很多,然后也是注意了一些新 ...

  4. WAMP中mysql服务突然无法启动 解决方法

    wamp的mysql服务前两天还能用,今天突然不能无法启动了,原因可能是近期电脑强行关机,删除wamp\bin\mysql\mysql5.6.17\data目录下的ib_logfile0和ib_log ...

  5. Spfa求最短路径

    spfa求最短路径,其思想就是遍历每一个点,将没有入队的点入队,从这个点开始不断修改能够修改的最小路径,直到队空.不过这里一个点可以重复入队. 这个需要有存图的基础--------->前向星存图 ...

  6. Ubuntu 16.04 安装Go 1.9.2

    系统环境 Ubuntu: 16.04 Go: 1.9.2 安装步骤 $ curl -O https://storage.googleapis.com/golang/go1.9.linux-amd64. ...

  7. scrapyd和scrapyd-client使用教程

    原文地址:http://blog.wiseturtles.com/posts/scrapyd.html Tags scrapyd scrapy scrapyd-client By crazygit O ...

  8. CPU的概念

    1.CPU的运算都是以纳秒为单位的,内存相比要慢百倍,硬盘要慢百万倍. 2.CPU的主要工作就是运行指令,指令全在内存里,第一条指令地址为0xFFFFFF0处(BIOS发出的跳转指令). 3.CPU工 ...

  9. How to setup Tensorflow inception-v3 model on Windows

    There is Inception-v3 model python implementation on GitHub at: https://github.com/tensorflow/models ...

  10. jQuery属性操作总结

    jquery属性包括以下几个: attr(name|pro|key,val|fn) removeAttr(name) prop(n|p|k,v|f)1.6+ removeProp(name)1.6+ ...