Python中dict.fromkeys的使用方法

Python中dict.fromkeys的使用方法codedict.fromkeys(keys[, value])/code是Python字典(dict)类中的一个静态方法,用于创建并返回一个新的字典,其中包含指定键序列(keys)中所有键的键值,默认的键值是None。

一、基本介绍

dict.fromkeys(keys[, value])是Python字典(dict)类中的一个静态方法,用于创建并返回一个新的字典,其中包含指定键序列(keys)中所有键的键值,默认的键值是None。

二、基本用法

dict.fromkeys()的基本使用方法如下:

keys = ['a', 'b', 'c']
d = dict.fromkeys(keys)
print(d) # {'a': None, 'b': None, 'c': None}

上面的代码创建了一个新的字典d,其中包含了指定键序列keys中所有键的键值,默认为None。

除此之外,dict.fromkeys()还可以指定键值,例如:

d = dict.fromkeys(keys, 0)
print(d) # {'a': 0, 'b': 0, 'c': 0}

上面的代码中,指定了键值为0,因此创建的字典d中所有键的键值都是0。

三、添加自定义键值对

除了以上两种方式,dict.fromkeys()还支持一种更加高级的用法,即通过传入一个可迭代对象,将其元素作为字典中的键,同时给每个键指定一个相同的值:

keys = ['a', 'b', 'c']
values = [1, 2, 3]
d = dict.fromkeys(keys, 0)
for k, v in zip(keys, values):
    d[k] = v
print(d) # {'a': 1, 'b': 2, 'c': 3}

上面的代码中,先创建了一个包含所有键的默认字典d,然后通过zip(keys, values)对两个列表进行了配对,再遍历所有键值对,将对应的键值赋给字典d中的键,从而得到一个自定义的字典。

四、源码分析

下面是dict.fromkeys()的源码实现:

@classmethod
def fromkeys(cls, iterable, value=None):
    d = cls()
    for key in iterable:
        d[key] = value
    return d

该方法是class method类型,因此调用时可以使用类名,例如dict.fromkeys()

在该实现中,首先通过cls创建了一个新的字典对象d,然后再遍历输入的键序列iterable,为每个键指定相同的值value,最终返回创建好的字典对象d。

五、总结

dict.fromkeys()是一个常见且十分实用的字典函数,通过它可以快速创建一个包含指定键的新字典,同时可以指定键对应的默认值。在实际的Python开发中经常用到该函数,当处理字典时有时可以通过该函数来简化代码,提高开发效率。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/21525.html

(0)
上一篇 2024-04-04
下一篇 2024-04-04

相关推荐

  • Pirhun: Python编写爬虫程序的利器

    Pirhun: Python编写爬虫程序的利器Pirhun是一个Python编写的爬虫框架,它提供了简单易懂的API,可以帮助开发者快速构建爬虫程序。它可以支持多线程、异步IO,还提供了强大的数据处理能力,能够帮助你高效地爬取各种网站的数据。

    2023-12-19
    75
  • SQL Pretty Printer 一款值得你拥有的MSSQL格式化插件

    SQL Pretty Printer 一款值得你拥有的MSSQL格式化插件各位码农小伙伴们,在使用MSSQL编辑器时候是否觉得没有一款格式化工具,写出来的代码很不美观,在团队中,做code review时候,每个人风格不一,对比不够直接呢? 我给大家推荐一款SQL Pret

    2023-02-22
    107
  • SQL优化这5个极简法则,直接让查询原地起飞![亲测有效]

    SQL优化这5个极简法则,直接让查询原地起飞![亲测有效]SQL 作为关系型数据库的标准语言,是 IT 从业人员必不可少的技能之一。SQL 本身并不难学,编写查询语句也很容易,但是想要编写出能够高效运行的查询语句却有一定的难度。
    查询优化是一个复杂的工程,涉

    2023-05-30
    95
  • Python split函数用于字符串分割

    Python split函数用于字符串分割在Python中,字符串是一种常见的数据类型,而字符串分割是在操作字符串时经常需要用到的操作之一。Python提供了一个内置的split()函数,可以对字符串进行分割。该函数非常灵活,可以以指定的分隔符为基础,对字符串进行分割,并返回一个分隔后的列表。在本文中,我们将详细介绍Python split函数的使用。

    2023-12-15
    76
  • SQL 常用的函数:算术函数、字符串函数、日期函数和转换函数[通俗易懂]

    SQL 常用的函数:算术函数、字符串函数、日期函数和转换函数[通俗易懂]不仅 SQL,对所有的编程语言来说,函数都起着至关重要的作用。函数就像是编程语言的“道具箱”,每种编程语言都准备了非常多的函数。 使用函数,我们可以实现计算、字符串操作、日期计算等各种各样的运算。 本

    2023-05-22
    102
  • Python查看版本命令

    Python查看版本命令a href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2024-04-27
    41
  • Redis详解(一)冰叔带你了解Redis[通俗易懂]

    Redis详解(一)冰叔带你了解Redis[通俗易懂]Redis 是一种基于 键值对 的 NoSQL 数据库。与很多键值对数据库不同,Redis 提供了丰富的 值数据存储结构,包括 string(字符串)、hash(哈希)、list(列表)、set(集…

    2022-12-24
    122
  • MySQL数据库基础_易码黄了吗

    MySQL数据库基础_易码黄了吗大家好!我是黄啊码,今天没继续select * 了吧,如果还继续,那接下来的课程先别学,回去好好把之前的课程重复复习一遍,学明白了我们再会?废话不多说,学今天的课程之前我们先来说说这几个词是怎么个执行

    2023-05-27
    107

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注