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

python容器之字典详解

itomcoil 2025-03-11 17:11 19 浏览

字典与列表类似,也是可变序列,不过不同的是字典是无序的可变序列,它的元素是通过键值对的形式存放的,键是唯一的,值是可变的。

字典的主要特征:

  • 通过键而不是通过索引来访问
  • 字典是无序的可变序列
  • 字典是可变的,而且可以任意嵌套
  • 字典的键必须是唯一且不可变的

一:字典的创建

字典的定义形式为:字典变量名 ={key:value,....}。

这里面key代表索引值,而value代表映射的值,通过大括号将其括起来进行字典的定义。

1.1,使用{}或者函数dict()创建

>>> dictx={} #直接生成一个空字典 dictx
>>> dict3 = dict() #创建一个空字典dict3,生成空字典建议使用工厂函数list

1.2,通过将包含双值子序列的序列转换成字典

通过将key和value作为一个序列类型(元组或列表)创建一个字典

a = (('李宁','一切皆有可能'),('python','编程改变世界'))
a也可以是以下形式:
a = [('李宁','一切皆有可能'),('python','编程改变世界')]
a = (['李宁','一切皆有可能'],['python','编程改变世界'])
a = [['李宁','一切皆有可能'],['python','编程改变世界']]
>>> dict4 = dict(a)
>>> dict4
{'李宁': '一切皆有可能', 'python': '编程改变世界'}

1.3,通过对关键字赋值创建一个字典,

注意关键字必须是一个字符串类型且不能加引号,因为程序会默认为其加上一个引号

>>> dict5 = dict(李宁='一切皆有可能', python='让编程改变世界')
>>> dict5
{'李宁': '一切皆有可能', 'python': '编程改变世界'}

1.4,使用内置函数 fromkeys

fromkeys(iterable, value=None, /)创建并返回一个新的字典。

  • 第一个参数是一个可迭代对象(序列),
  • 第二个参数是value值,当第二个参数不提供时,则默认为none

特别说明:建议使用list()创建空字典

>>> dict1 = dict()
>>> dict2 = dict1.fromkeys((1, 2, 3), 'number')
>>> dict2
{1: 'number', 2: 'number', 3: 'number'}
>>> dict3 = dict1.fromkeys((1, 2, 3))
>>> dict3
{1: None, 2: None, 3: None}

二:字典访问

2.1,直接使用dict[key]

注意:如果key不存在字典中,无法访问,且会报错

>>> dict1 = {1:'one',2:'two',3:'three'}
>>> dict1[2]
'two'

2.2,使用内置函数 get(k[,d]),通过key返回对应的value值,

  • 第一个参数为key值,
  • 第二个参数d为默认返回的value值,

当key存在则返回对应的值,不存在字典内时返回该valuevalue值,如果不提供则默认为 none

>>> dict5 = {1:'one',2:'two',3:'three'}
>>> dict5.get(3,'木有')
'three'
>>> dict5.get(4,'木有')
'木有'
>>> dict5.get(4)
>>> print(dict5.get(4))
None

三:单独访问 key,value,及item

  • keys() 返回字典所有的key,返回可迭代对象,
  • values() 返回字典所有的value,返回可迭代对象
  • items() 返回字典所有的 item,返回可迭代对象

举例说明:

>>> dict4={1:'one',2:'two',3:'three'}
>>> dict4.keys()        #返回字典的所有key值
dict_keys([1, 2, 3])
>>> dict4.values()
dict_values(['one', 'two', 'three'])
>>> dict4.items()
dict_items([(1, 'one'), (2, 'two'), (3, 'three')])

四:修改或增加字段元素

4.1,使用[key]=value 添加或修改元素

当key值存在于字典内时,则重置key的value值 ,相当于修改

当key值不存在于字典内时,则字典增加一个键值对(key:value)

>>> dict6 = {'李宁': '一切皆有可能', 'python': '让编程改变世界'}
>>> dict6['李宁'] = '非一般'
>>> dict6
{'李宁': '非一般', 'python': '让编程改变世界'}
>>> dict6['fruit']='apple'
>>> dict6
{'fruit': 'apple', '李宁': '非一般', 'python': '让编程改变世界'}

4.2,使用内置函数 update

  • 对于不存在的键值对 ,则添加key-value
  • 对于存在的键值对,则修改key对应的值
>>> dict7 = {1: 'one', 2: None, 3: 'three'}
>>> dict8 = {4:'four'}
>>> dict7.update(dict8)            #对于不存在的key ,key-value则添加
>>> dict7
{1: 'one', 2: None, 3: 'three', 4: 'four'}
>>> dict9 = {2:'two'}
>>> dict7.update(dict9)          #对于存在的key,则修改key对应的值
>>> dict7
{1: 'one', 2: 'two', 3: 'three', 4: 'four'}

4.3,函数setdefault(k[,d])

k表示键,用于在字典中查找指定键对应的值,既可以访问字典,又可以修改字典

  • - k不在字典内时 新增一个键值对item 同时返回d的值,如果d没提供则返回空
  • - k存在字典内时,把该键对应的值返回,不会在字典中添加新的键值对
>>> dict7 ={3: 'three'}
>>> dict7.setdefault(1,'one') #1不存在字典中, 返回设定的one,同时新增一个键值对
'one'
>>> dict7
{1: 'one', 3: 'three'}
>>> dict7.setdefault(2) #2不在字典中,但是没有设置参数d,默认返回None,同时新增一个键值对(2,None)
None
>>> dict7
{1: 'one', 2: None, 3: 'three'}
>>> dict7.setdefault(3,'有') #3存在,返回3对应的three
'three'


五:字典删除和清空

5.1,pop(k[,d]) 删除字典的键值对。

  • - 当k存在字典的key时,在字典内去除该key对应的(key,value)并返回对应的value,
  • - 当k不存在字典的key时,返回d的值,如果不提供d则返回错误,
dict7={1: 'one', 2: 'two', 3: 'three'}
>>> dict7.pop(1,'木有')
'one'
>>> dict7
{2: 'two', 3: 'three'}
>>> dict7.pop(1,'木有')
'木有'
>>> dict7.pop(1)
KeyError: 1

5.2,popitem()

删除字典内的一个(key,value),并返回该键值对,如果字典本身为空时报错

>>> dict7
{2: 'two', 3: 'three'}
>>> dict7.popitem()
(2, 'two')
>>> dict7
{3: 'three'}

5.3,使用del删除指定键的元素

>>> dict1 = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}
>>> del dict1['apple']
>>> dict1
{'banana': 3, 'pear': 1, 'orange': 2}

5.4,clear() 字典清空

>>> dict7.clear()
>>> dict7
{}

六:字典复制

copy() 相当于复制出一个新的字典

>>> dict5 = {1: 'one', 2: 'two', 3: 'three'}
>>> dict6 = dict5     #赋值操作,相当于贴了个新标签,内存地址不变
>>> id(dict6)            #查看对象内存地址
58796168
>>> id(dict5)
58796168
>>> dict7 = dict5.copy() #copy()相当于复制出一个新的字典
>>> id(dict7)
58795208
>>> dict6.clear() #当清除dict6时,dict5也一并清除
>>> dict6
{}
>>> dict5
{}
>>> dict7 #copy()复制出的新的字典不会被清空
{1: 'one', 2: 'two', 3: 'three'}

六:获取字典中最大的值对应的键

命名参数key接受一个函数,该函数接受一个参数并返回一个可以比较大小的对象,max返回使该函数的返回值最大的成员。传dict.get时,就会对dict中每个键返回对应的值,这样找到的就是值最大的键。

dict1={'a':10,'b':15,'c':5}
max(dict1,key=dict1.get)
'b'
min(dict1,key=dict1.get)
'c'

相关推荐

《Queendom》宣布冠军!女团MAMAMOO四人激动落泪

网易娱乐11月1日报道据台湾媒体报道,南韩女团竞争回归的生死斗《Queendom》昨(10/31)晚播出大决赛,并以直播方式进行,6组女团、女歌手皆演唱新歌,并加总前三轮的赛前赛、音源成绩与直播现场投...

正确复制、重写别人的代码,不算抄袭

我最近在一篇文章提到,工程师应该怎样避免使用大量的库、包以及其他依赖关系。我建议的另一种方案是,如果你没有达到重用第三方代码的阈值时,那么你就可以自己编写代码。在本文中,我将讨论一个在重用和从头开始编...

HTML DOM tr 对象_html event对象

tr对象tr对象代表了HTML表格的行。HTML文档中出现一个<tr>标签,就会创建一个tr对象。tr对象集合W3C:W3C标签。集合描述W3Ccells返回...

JS 打造动态表格_js如何动态改变表格内容

后台列表页最常见的需求:点击表头排序+一键全选。本文用原生js代码实现零依赖方案,涵盖DOM查询、排序算法、事件代理三大核心技能。效果速览一、核心思路事件入口:为每个<th>绑...

连肝7个晚上,总结了66条计算机网络的知识点

作者|哪吒来源|程序员小灰(ID:chengxuyuanxiaohui)计算机网络知识是面试常考的内容,在实际工作中经常涉及。最近,我总结了66条计算机网络相关的知识点。1、比较http0....

Vue 中 强制组件重新渲染的正确方法

作者:MichaelThiessen译者:前端小智来源:hackernoon有时候,依赖Vue响应方式来更新数据是不够的,相反,我们需要手动重新渲染组件来更新数据。或者,我们可能只想抛开当前的...

为什么100个前端只有1人能说清?浏览器重排/重绘深度解析

面试现场的"致命拷问""你的项目里做过哪些性能优化?能具体讲讲重排和重绘的区别吗?"作为面试官,我在秋招季连续面试过100多位前端候选人,这句提问几乎成了必考题。但令...

HTML DOM 介绍_dom4j html

HTMLDOM(文档对象模型)是一种基于文档的编程接口,它是HTML和XML文档的编程接口。它可以让开发人员通过JavaScript或其他脚本语言来访问和操作HTML和XML文档...

JavaScript 事件——“事件流和事件处理程序”的注意要点

事件流事件流描述的是从页面中接收事件的顺序。IE的事件流是事件冒泡流,而NetscapeCommunicator的事件流是事件捕获流。事件冒泡即事件开始时由最具体的元素接收,然后逐级向上传播到较为不...

探秘 Web 水印技术_水印制作网页

作者:fransli,腾讯PCG前端开发工程师Web水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印)...

国外顶流网红为流量拍摄性侵女学生?仅被封杀三月,回归仍爆火

曾经的油管之王,顶流网红DavidDobrik复出了。一切似乎都跟他因和成员灌酒性侵女学生被骂到退网之前一样:住在950万美元的豪宅,开着20万美元的阿斯顿马丁,每条视频都有数百万观看...人们仿佛...

JavaScript 内存泄漏排查方法_js内存泄漏及解决方法

一、概述本文主要介绍了如何通过Devtools的Memory内存工具排查JavaScript内存泄漏问题。先介绍了一些相关概念,说明了Memory内存工具的使用方式,然后介绍了堆快照的...

外贸独立站,网站优化的具体内容_外贸独立站,网站优化的具体内容有哪些

Wordpress网站优化,是通过优化代码、数据库、缓存、CSS/JS等内容,提升网站加载速度、交互性和稳定性。网站加载速度,是Google搜索引擎的第一权重,也是SEO优化的前提。1.优化渲染阻塞。...

这8个CSS工具可以提升编程速度_css用什么编译器

下面为大家推荐的这8个CSS工具,有提供函数的,有提供类的,有提取代码的,还有收集CSS的统计数据的……请花费两分钟的时间看完这篇文章,或许你会找到意外的惊喜,并且为你的编程之路打开了一扇新的大门。1...

vue的理解-vue源码 历史 简介 核心特性 和jquery区别 和 react对比

一、从历史说起Web是WorldWideWeb的简称,中文译为万维网我们可以将它规划成如下的几个时代来进行理解石器时代文明时代工业革命时代百花齐放时代石器时代石器时代指的就是我们的静态网页,可以欣...