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

利用VBA字典汇总数据,真的非常简单

itomcoil 2025-03-06 16:07 4 浏览

大家好,今日我们继续讲解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学习——029统计【字典的列表】里符合条件元素数量

方式一:使用普通for循环students=[{'name':'jack','points':100},{'...

玩转Python—列表使用教程

上一讲给大家介绍了Python的列表,今天继续给大家介绍Python中列表的使用。1.列表的元素的赋值#实例>>>num=[1,2,3,4,5,6,7,7,8,8,9]>...

python学习——030如何将列表中的元素按要求分类

方法一:原代码方法(使用while循环结合pop方法)创建了numbers列表的一个副本temp_numbers,在循环中对temp_numbers进行操作,保证原列表numbers的内...

Python 条件判断教程

Let'sdivein!1.基本的if语句(ifStatement)在Python中,if语句用来根据条件执行代码块。当条件为True(真)时,代码块将被执行;否则,...

list列表基本操作

【实验目的】1、掌握list列表的基本操作【实验原理】列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表的数据项不需要具有相同的类型。列表中的每个元素都分配一个数字-它...

Python变量类型判断方法详解

技术背景在Python编程中,变量类型的判断是一项基础且重要的操作。由于Python是动态类型语言,变量的类型在运行时才能确定,因此在开发过程中,我们常常需要明确变量的类型,以便进行相应的操作。同时,...

基础知识详解:Python any()函数的使用方法(含示例代码)

前言:今天为大家带来的内容是:Pythonany()函数的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,要是喜欢本文章内容的朋友,一定不忘点赞转发关注收藏不迷...

新手学Python避坑,学习效率狂飙! 八、Python 布尔值判断

布尔值判断系统知识在Python里,布尔类型仅有两个值:True和False,它们常被用于条件判断。下面从几个方面展开介绍:1.布尔运算逻辑与(and):只有当两个操作数都为True时,...

Python新手必看|列表操作全攻略(增删改查+切片+推导式)

一、为什么列表是Python的"万能容器"?作为最灵活的序列类型,列表支持:存储任意类型数据(数字/字符串/对象)动态增减元素快速索引访问丰富的内置方法python#创建包含不同数据...

Python列表集合操作介绍?

列表和集合是在Python编程中比较常用,而且比较常见的两种数据结构,他们有着各自的特点以及使用场景,下面我们就来详细的介绍一下列表和集合在实际使用中的一些操作对比。List(列表)列表操作的特点就是...

对Python中序列的个人理解

序列指的是一块连续内存空间存放多个值,在python中,序列类型包括字符串、列表、字典、元组、集合。其中包括字符串、列表、元组为有序序列,字典、集合属于无序序列。例如:#定义变量name,并赋值为字...

python 数据结构之列表(list)简述及演示

(一)list列表定义使用中括号[],里面元素可以是任意类型,包括列表本身,也可以是字典、元组等。(二)在Python中,第一个列表元素的索引为0,而不是1。(三)要访问列表的任何元素,都可将...

Python 列表(List)详解

列表是Python中最基本、最常用的数据结构之一,它是一个有序的、可变的元素集合。一、列表的基本操作1.创建列表#空列表empty_list=[]empty_list=list()...

自学Python第九天——操作列表

自学Python第九天——操作列表一、遍历整个列表1、需要对列表中的每个元素进行相同的操作时,使用for循环例如前几张我们学过的一些内容,想将列表中的每个元素打印出来,需要不断地重复代码,而且因列表长...

Python 列表(List)完全指南:数据操作的利器

在Python中,列表(list)是一种可变序列(mutablesequence),它允许我们存储和操作一组有序数据(ordereddata)。本教程将从基础定义(basicdefiniti...