百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

利用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()等操作起来非常简单,但是这些方法的底层却是很复杂的,这里面涉及到一些操作系统的...