利用VBA字典汇总数据,真的非常简单
itomcoil 2025-03-06 16:07 7 浏览
大家好,今日我们继续讲解VBA数组与字典解决方案,今日讲解第79讲内容:利用字典汇总数据的几种常见方法总结。
利用字典汇总并提取数据,是我们经常要用到的,利用字典排重性可以很方便得到一个主键不重复的数据汇总,在以往的各个章节中,我利用了各种方法达到这个目的,今日我就这个问题做一个总结,看看利用字典汇总数据的时候,都有哪些基本的方法,代码如何书写,还是以结合实例来讲解。
实例,如下面的截图,我们要根据A,B列数据的编号汇总一下各个编号的总金额。字典学习到这里,这个代码应该是很简单的了。
下面看我给出的代码:
Sub mynzsz_79() '第79讲 利用字典汇总数据的几种常见的方式总结
Sheets("79").Select
Set mydic = CreateObject("Scripting.Dictionary")
For i = 2 To UBound(myarr)
'第一种:用item方法
' mydic.Item(myarr(i, 1)) = mydic.Item(myarr(i, 1)) + myarr(i, 2)
'第二种:用dic(key)方法
'mydic(myarr(i, 1)) = mydic(myarr(i, 1)) + myarr(i, 2)
'第三种:用dic.add方法
If Not mydic.exists(myarr(i, 1)) Then
mydic.Add myarr(i, 1), myarr(i, 2)
Else
'第1种写法:key写法
'mydic(myarr(i, 1)) = mydic(myarr(i, 1)) + myarr(i, 2)
'第2中:item 写法
mydic.Item(myarr(i, 1)) = mydic.Item(myarr(i, 1)) + myarr(i, 2)
End If
Next
'清空数据区域,回填数据
[e:f].Clear
Range("a1:b1").Copy Range("e1")
Range("e2").Resize(UBound(mydic.Keys) + 1, 1) = Application.Transpose(mydic.Keys)
Range("f2").Resize(UBound(mydic.Keys) + 1, 1) = Application.Transpose(mydic.Items)
Set mydic = Nothing
End Sub
代码的截图:
代码分析:
1 上述代码中,我先后共有三种的书写方法,这三种方法都是实测可以利用的,学习的朋友可以根据自己的需要,或者自己的习惯选择其中的方法使用。
2 Set mydic = CreateObject("Scripting.Dictionary")
myarr = Range("a1").CurrentRegion.Value
上面的语句是创建字典,把要分析的数据装入字典,CurrentRegion的含义是返回Range对象,该对象代表当前的区域。当前区域是一个边缘是任意空行和空列组合成的范围,要理解这个概念,我在实际使用的时候,会更多的用区域的可控选择,大家可以在我的代码中经常看到,如:myarr = Range("a2:b" & Range("a2").End(xlDown).Row)
3 '第一种:用item方法
' mydic.Item(myarr(i, 1)) = mydic.Item(myarr(i, 1)) + myarr(i, 2)
上述语句是汇总数据的第一种写法,利用了键值item.
4 '第二种:用dic(key)方法
'mydic(myarr(i, 1)) = mydic(myarr(i, 1)) + myarr(i, 2)
上述语句是汇总数据的第二种写法,更加的直观,但在字典多重嵌套的时候,看上去和理解起来有些难度了。
5 '第三种:用dic.add方法
If Not mydic.exists(myarr(i, 1)) Then
mydic.Add myarr(i, 1), myarr(i, 2)
Else
'第1种写法:key写法
'mydic(myarr(i, 1)) = mydic(myarr(i, 1)) + myarr(i, 2)
'第2中:item 写法
mydic.Item(myarr(i, 1)) = mydic.Item(myarr(i, 1)) + myarr(i, 2)
End If
上述语句是第三种写法是用mydic.Add和第二种方法的结合,理解起来不是很难的。
6 Range("e2").Resize(UBound(mydic.Keys) + 1, 1) = Application.Transpose(mydic.Keys)
Range("f2").Resize(UBound(mydic.Keys) + 1, 1) = Application.Transpose(mydic.Items)
上述语句回填数据,应用的时候非常的方便。
下面看代码的运行,是采用第三种方法代码:
今日内容回向:
1 利用字典在做数据汇总的时候,有哪些方法可以利用?
2 数据回填的时候,还有哪些方法呢?
相关推荐
- python unittest 基本用法(python pytest)
-
unittest的使用分为6个步骤:1.导入unittest模块2.定义测试类,父类为unittest.TestCase可继承unittest.TestCase的方法,如setUp和tearDown方...
- python中如何利用递归原理找出文件夹中的全部文件
-
在python中要想查看文件夹中的文件,需要先导入os模块,在python中导入os模块后,定义一个空的列表,用来接收返回的文件,importoslist1=[]接下来,我们定义一个函数,这个函...
- Python读取配置文件(config.ini),写入配置文件
-
一、读取配置文件我的目录如下,在config下有一个config.ini配置文件配置文件内容#定义config分组[config]platformName=AndroidappPackage...
- python 文件操作(python文件操作添加下一行)
-
在Python中,可以使用内置的文件操作函数和方法来进行文件的读取、写入和操作。下面是一些常见的文件操作方法:打开文件:使用open()函数来打开一个文件,并返回一个文件对象。你需要指定文件的路径和打...
- 失业程序员复习python笔记——excel读写处理
-
Excel是我们在工作中用到的最频繁的软件之一,它有着强大的计算能力和便捷的图表功能。今天记录一下怎么用python操作excel文件安装excel扩展库如果要用Python操作Excel文...
- Python的文件处理(python文件处理方法)
-
一、文件处理的流程1.打开文件,得到文件句柄并赋值给一个变量2.通过句柄对文件进行操作3.关闭文件示例:d=open('abc')data1=d.read()pri...
- Python读写docx文件(python如何读写文件)
-
Python读写docx文件Python读写word文档有现成的库可以处理pipinstallpython-docx安装一下。https://python-docx.readthedocs.io/...
- (简单入门易懂)实例详解:Python csv文件的读写操作
-
今天为大家带来的内容是:简单入门易懂的是咧详解:Pythoncsv文件的读写操作本文内容主要介绍了Pythoncsv文件的读写操作实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有...
- Python3查看文件是否存在,以及读、写与执行的属性
-
目录技术背景代码实现测试分析总结概要版权声明技术背景在使用python对系统文件进行操作的项目中,经常需要用到对本地文件的存在和读写进行判断的操作。最常用的比如os.exists函数,可以很方便的判断...
- Python常用文件操作库使用详解(python中文件操作的例子)
-
Python生态系统提供了丰富的文件操作库,可以处理各种复杂的文件操作需求。本教程将介绍Python中最常用的文件操作库及其实际应用。一、标准库核心模块1.1os模块-操作系统接口主要功能:文件...
- python入门 输入与输出——读和写文件
-
以下是Python文件读写的入门指南,包含基础操作、安全写法及实用技巧:一、文件操作基础步骤打开文件→读写操作→关闭文件(务必确保最后关闭文件,避免资源泄露)二、文件读取1.基本读取#方法...
- 第41讲 基本文件操作(和猫妹学Python)
-
小朋友们好,大朋友们好!我们今天基本文件操作,要学习的内容如下:什么是文件,什么是目录创建和打开文件关闭文件with语句打开文件写入文件内容读取文件什么是文件,什么是目录文件是计算机存储信息的一种形式...
- Python自动化办公自学笔记(八)文件操作
-
一、文件使用在Python里面,文件分为两种类型,一种是文本文件,后缀名为“.txt”,由单一特定编码的字符组成;另一种是二进制文件,由比特0和比特1组成。Python对以上两种文件都有统一的操作步骤...
- python 利用python读取DOC文件(python读取word数据)
-
近期公司需要处理一批DOC文件,而在windows系统中,python没有模块能直接读取doc文件。需要先把doc文件批量转成docx文件,再读取操作。linux系统python有模块可直接读取doc...
- Python学不会来打我(83)python读写文件操作总结
-
python读写文件操作其实是一个很复杂的过程,在python代码中给的内建函数open()、read()、write()等操作起来非常简单,但是这些方法的底层却是很复杂的,这里面涉及到一些操作系统的...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)