【Python】深入了解 defaultdict:轻松处理默认值与复杂数据结构

文章目录

    • 1. 深入理解 Python 中的 defaultdict:简化数据结构处理的利器
    • 2. defaultdict 基础概念
    • 3. 创建 defaultdict 实例
      • 3.1 基本用法
      • 3.2 使用其他工厂函数
    • 4. defaultdict 的应用场景
      • 4.1 计数器
      • 4.2 分组数据
    • 5. defaultdict 的高级用法
      • 5.1 嵌套 defaultdict
      • 5.2 自定义默认值
    • 6. 总结

1. 深入理解 Python 中的 defaultdict:简化数据结构处理的利器

在 Python 的标准库中,collections 模块提供了许多强大的数据结构,其中 defaultdict 是一个非常实用的工具。defaultdict 继承自内置的 dict 类型,它可以在访问不存在的键时自动提供默认值,这一特性使得处理复杂的数据结构变得更加简单和直观。在这篇文章中,我将详细介绍 defaultdict 的使用方法和应用场景,并通过代码示例帮助理解它的强大功能。

2. defaultdict 基础概念

defaultdict 的工作原理与普通的字典类似,但它允许你为不存在的键设置一个默认值。创建一个 defaultdict 对象时,需要传入一个工厂函数,这个函数返回你希望在访问不存在的键时使用的默认值。这样,当你试图访问一个不存在的键时,defaultdict 会自动调用工厂函数并使用其返回值来填充缺失的项,而不会引发 KeyError 异常。

3. 创建 defaultdict 实例

3.1 基本用法

from collections import defaultdict# 创建一个 defaultdict,默认值为整数 0
dd = defaultdict(int)# 添加一些键值对
dd['apple'] = 10
dd['banana'] = 5# 访问存在的键
print(dd['apple'])  # 输出: 10# 访问不存在的键,自动创建键并设置默认值 0
print(dd['orange'])  # 输出: 0# 打印 defaultdict 对象的内容
print(dd)  # 输出: defaultdict(<class 'int'>, {'apple': 10, 'banana': 5, 'orange': 0})

解释: defaultdict(int) 创建了一个 defaultdict 对象,其中 int 是一个工厂函数,返回 0。访问已存在的键时,defaultdict 会返回对应的值。访问不存在的键时,defaultdict 会调用 int() 函数,返回默认值 0。

3.2 使用其他工厂函数

defaultdict 可以使用各种工厂函数来生成默认值。例如,可以使用 list 工厂函数来创建一个默认值为列表的 defaultdict

from collections import defaultdict# 创建一个 defaultdict,默认值为空列表
dd = defaultdict(list)# 添加一些键值对
dd['fruits'].append('apple')
dd['fruits'].append('banana')
dd['vegetables'].append('carrot')# 打印 defaultdict 对象的内容
print(dd)  # 输出: defaultdict(<class 'list'>, {'fruits': ['apple', 'banana'], 'vegetables': ['carrot']})

解释: defaultdict(list) 创建了一个 defaultdict 对象,其中 list 是一个工厂函数,返回一个空列表。当访问不存在的键时,defaultdict 会自动创建一个空列表作为默认值。这对于将多个值归类到相同的键下非常有用。

4. defaultdict 的应用场景

4.1 计数器

使用 defaultdict 进行计数是一种常见的应用场景。例如,计算字符串中每个字符出现的次数。

from collections import defaultdicttext = "hello world"
char_count = defaultdict(int)for char in text:char_count[char] += 1# 打印字符计数结果
print(dict(char_count))  # 输出: {'h': 1, 'e': 1, 'l': 3, 'o': 2, ' ': 1, 'w': 1, 'r': 1, 'd': 1}

解释: defaultdict(int) 被用来计数字符串 text 中每个字符的出现次数。每次访问字符时,defaultdict 会自动初始化计数器为 0,然后加 1。这种方式使得计数操作变得非常简洁。

4.2 分组数据

defaultdict 也可以用来对数据进行分组。例如,将数据按类别进行分组并存储在列表中。

from collections import defaultdictdata = [('fruit', 'apple'),('fruit', 'banana'),('vegetable', 'carrot'),('fruit', 'orange'),('vegetable', 'broccoli')
]grouped_data = defaultdict(list)for category, item in data:grouped_data[category].append(item)# 打印分组后的数据
print(dict(grouped_data))  # 输出: {'fruit': ['apple', 'banana', 'orange'], 'vegetable': ['carrot', 'broccoli']}

解释: defaultdict(list) 用于将数据按类别进行分组。每次遇到一个新的类别时,defaultdict 会自动创建一个空列表,然后将项追加到该列表中。这种方法在处理分类数据时非常高效。

5. defaultdict 的高级用法

5.1 嵌套 defaultdict

有时需要创建多层嵌套的字典结构。可以使用 defaultdict 创建嵌套字典来实现这一点。

from collections import defaultdict# 创建一个嵌套的 defaultdict
nested_dd = defaultdict(lambda: defaultdict(int))# 添加数据
nested_dd['2024']['January'] = 5
nested_dd['2024']['February'] = 8
nested_dd['2025']['January'] = 3# 打印嵌套的 defaultdict 对象
print(dict(nested_dd))  
# 输出: {'2024': {'January': 5, 'February': 8}, '2025': {'January': 3}}

解释: 在这个示例中,使用了一个 lambda 函数来创建嵌套的 defaultdict。外层 defaultdict 的默认值是另一个 defaultdict(int),这使得可以创建一个多层嵌套的字典结构。这样可以方便地组织复杂的数据层次。

5.2 自定义默认值

除了使用内置的工厂函数,还可以定义自定义的默认值生成函数。例如,可以创建一个 defaultdict,其默认值为自定义的对象或计算结果。

from collections import defaultdictclass CustomObject:def __init__(self, value):self.value = valuedef __repr__(self):return f"CustomObject(value={self.value})"def default_value():return CustomObject("default")# 创建一个 defaultdict,默认值为 CustomObject 对象
custom_dd = defaultdict(default_value)# 访问不存在的键
print(custom_dd['key'])  # 输出: CustomObject(value=default)# 打印 defaultdict 对象的内容
print(custom_dd)  # 输出: defaultdict(<function default_value at ...>, {'key': CustomObject(value=default)})

解释: 在这个示例中,定义了一个 CustomObject 类,并创建了一个 defaultdict,其默认值为 CustomObject 实例。通过自定义的 default_value 函数,defaultdict 可以创建具有特定属性的默认对象。

6. 总结

defaultdict 是一个非常强大的工具,在处理字典数据结构时可以显著简化代码和提高效率。它不仅能够自动提供默认值,还能够与各种工厂函数和自定义函数结合使用,适应不同的数据处理需求。从简单的计数到复杂的嵌套字典,defaultdict 的灵活性和便利性使得它在许多应用场景中成为了不可或缺的工具。

希望这篇文章能帮助你更好地理解和使用 defaultdict,并将其应用到实际项目中。


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/46813.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么流程图在项目管理中如此重要?

在我们的日常学习生活中&#xff0c;是不是感觉工作复杂繁琐&#xff0c;知识杂乱无章呢&#xff1f;那么流程图能够完美的解决这个问题&#xff0c;本文将会用一篇文章告诉你什么是流程图&#xff0c;流程图简单来说就是一种以图形方式表示算法、工作流程或过程的图表&#xf…

云服务器重置密码后,xshell远程连接不上,重新启用密码登录方式

云服务器重置密码后 &#xff0c;xshell连接出现不能使用密码登录 解决方案&#xff1a;以下来自阿里云重新启用密码登录方式帮助文档 为轻量应用服务器创建密钥且重启服务器使密钥生效后&#xff0c;服务器会自动禁止使用root用户及密码登录。如果您需要重新启用密码登录方式&…

零基础自学爬虫技术该从哪里开始入手?

零基础自学爬虫技术可以从以下几个方面入手&#xff1a; 一、学习基础编程语言 Python 是爬虫开发的首选语言&#xff0c;因此首先需要学习 Python 编程语言的基础知识。这包括&#xff1a; 语法基础&#xff1a;学习 Python 的基本语法&#xff0c;如变量定义、数据类型、控…

数据结构-java中链表的存储原理及使用方式

目录 链表&#xff08;线性表的链式存储&#xff09; 代码实例&#xff1a;&#xff08;链表构建&#xff0c;头插尾插&#xff09; LinkedList LinkedList的使用&#xff1a; 1、构造方法 2、操作方法 LinkedList 和 ArrayList 的区别 链表&#xff08;线性表的链式存储…

基于python的图像去水印

1 代码 import cv2 import numpy as npdef remove_watermark(image_path, output_path):# 读取图片image cv2.imread(image_path)# 转换为灰度图gray cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 使用中值滤波去除噪声median_filtered cv2.medianBlur(gray, 5)# 计算图像的梯…

windows11安装qemu启动树莓派2b连接网卡和openssh-server

》》。下载window下的tap驱动 下载tap-window6(https://github.com/OpenVPN/tap-windows6/releases/download/9.26.0/dist.win7.zip) 》》。下载树莓派2b的img镜像 树莓派(raspberry pi)学习9: Qemu虚拟机联网&#xff08;主机和虚拟机互访、虚拟机可上网&#xff09;_qemu …

PyCharm 查找功能指南

1. 在文件内查找 1.1 快捷键&#xff1a;Ctrl F 在当前文件中查找文本时&#xff0c;可以使用快捷键 Ctrl F 来打开查找对话框。输入要查找的文本后&#xff0c;PyCharm 会高亮显示所有匹配的结果&#xff0c;并允许你逐个导航。 1.1.1 实用技巧 智能匹配&#xff1a; PyCh…

【Python学习笔记】:Python爬取音频

【Python学习笔记】&#xff1a;Python爬取音频 背景前摇&#xff08;省流可以不看&#xff09;&#xff1a; 人工智能公司实习&#xff0c;好奇技术老师训练语音模型的过程&#xff0c;遂请教&#xff0c;得知训练数据集来源于爬取某网页的音频。 很久以前看B站同济子豪兄的《…

实验三:图像的平滑滤波

目录 一、实验目的 二、实验原理 1. 空域平滑滤波 2. 椒盐噪声的处理 三、实验内容 四、源程序和结果 (1) 主程序&#xff08;matlab&#xff09; (2) 函数GrayscaleFilter (3) 函数MeanKernel (4) 函数MedFilter 五、结果分析 1. 空域平滑滤波 2. 椒盐噪声的处理…

【数据结构与算法 经典例题】判断二叉树是否对称

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《数据结构与算法 经典例题》C语言 期待您的关注 目录 一、问题描述 二、解题思路 三、C语言实现代码 一、问题描述 给你一个二…

STM32 不同时钟频率有什么不同的影响

#STM32为什么需要RCC时钟树 单片机本质上&#xff0c;是一个复杂的时序电路&#xff0c;而时序电路的行为依赖于&#xff0c;时钟信号来控制状态的变化&#xff0c;和数据的流动&#xff0c;如果没有时钟信号&#xff0c;单片机内部的时序逻辑将无法工作&#xff0c;整个系统将…

Linux---PXE高效装机

目录 一、系统安装 1.1 系统装机三种引导方式 1.2、系统安装过程 1.3 Linux 安装光盘的安装相关文件 二、PXE概述 2.1 什么是 PXE 2.2 PXE 批量部署的优点 2.3 实现过程(工作原理) 三、PXE 批量部署 3.1 安装开启 DHCP服务 3.2、安装并启用 TFTP 服务 3.3、安装ft…

C#传入JS的数据变了

因为JS和C#的二进制转换不一样,有时候会发生数据不一致的情况&#xff0c;需要在js代码中使用UTF8ToString()来进行转换一下就好了&#xff0c;还需要注意的是&#xff0c;C#对JSLib操作的时候&#xff0c;方法的顺序一定需要一致。 [DllImport("__Internal")] //上传…

AI论文精读笔记-MAE

1. 论文基本信息 论文标题&#xff1a;Masked Autoencoders Are Scalable Vision Learners 作者&#xff1a;Kaiming He∗,† Xinlei Chen∗ Saining Xie Yanghao Li Piotr Doll ́ ar Ross Girshick 发表时间和期刊&#xff1a;19 Dec 2021; arxiv 论文链接&#xff1a;Mas…

【大模型书籍】从零开始大模型开发与微调:基于PyTorch与ChatGLM(附PDF)

哈喽各位&#xff0c;今天又来给大家分享大模型学习书籍了&#xff0c;今天是这本<从零开始大模型开发与微调&#xff1a;基于PyTorch与ChatGLM 书籍PDF分享>&#xff0c;大模型是深度学习自然语言处理皇冠上的一颗明珠&#xff0c;也是当前AI和NLP研究与产业中最重要的方…

HTML+CSS+JS用户管理(可储存用户数据)

使用cookies记录账号密码信息&#xff0c;可以注册、登录、注销账号。 点赞❤️收藏⭐️关注&#x1f60d; 效果图 源代码在效果图后面 源代码 HTML <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <…

docker desktop历史版本安装

1.安装choco Windows安装 choco包管理工具-CSDN博客 2.通过choco安装 下面例子为安装旧版2.3.0.2,其它版本类似 Chocolatey Software | Docker Desktop 2.3.0.2 https://download.docker.com/win/stable/45183/Docker%20Desktop%20Installer.exe choco install docker-des…

前端报错adding CSS “touch-action: none“ to this element解决方案

目录 如图所示控制台出现报错&#xff1a; 原因&#xff1a; touch-action 介绍&#xff1a; 解决方案&#xff1a; 1.手动设置touch-action&#xff1a; 2.使用条件渲染&#xff1a; 3.CSS样式隔离&#xff1a; 4.浏览器兼容性&#xff1a; 5. 忽略警告 如图所示控制台…

Windows虚拟摄像头有哪些?分享5个方法,手机一键替换电脑摄像头!

Windows虚拟摄像头怎么用&#xff1f;当我们的电脑缺少摄像头时&#xff0c;我们可以借助虚拟摄像头实现。手机作为电脑摄像头的需求日益增长&#xff0c;本文就来给大家详细介绍&#xff0c;关于电脑虚拟摄像头的使用和说明&#xff0c;一起来看看吧&#xff01; &#xff08;…

SVN的使用和下载

SVN&#xff08;Subversion&#xff09;是一个开放源代码的版本控制系统&#xff0c;它用于管理随时间改变的数据&#xff0c;如源代码文件等。这些数据被放置在一个中央资料档案库&#xff08;Repository&#xff09;中&#xff0c;SVN能够跟踪文件的每一次变动&#xff0c;从…