热榜!万字长文第二篇:深入讲解python中一大数据结构之字典(叮叮当~小葵花课堂开课啦!)

Posted 孤寒rm-rf*

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了热榜!万字长文第二篇:深入讲解python中一大数据结构之字典(叮叮当~小葵花课堂开课啦!)相关的知识,希望对你有一定的参考价值。

在这里插入图片描述

引言——在Python中,通过数据结构来保存项目中重要的数据信息。Python语言内置了多种数据结构,例如列表,元组,字典和集合等。本堂课我们来讲一讲Python中举足轻重的一大数据结构——字典。

在Python程序设计中,字典是一种比较特别的数据类型。它以大括号“{}”包围,并且以“键:值”对的方式
声明存在的数据集合。字典与列表相比,最大的不同在于字典是无序的,其成员位置只是象征性的,在字典中
我们需要通过键来访问成员,而不能通过其位置来访问成员。

小考点——字典是python中唯一内建的映射类型哦!

在这里插入图片描述

第一小节课 之 认识字典:

那么,同学们,究竟什么是字典呢?难道是我们提笔忘字的时候拿出的那厚厚的一本《新华字典》吗?我可以很肯定的告诉同学们不是哦!不过呢?我们接下来要讲的字典跟这个大家印象里的字典有那么一些共同点哦!希望同学们学完之后能给我讲出来哦!

好了好了!同学们收收心,开始正式上课啦——在第一小节课老师会带领大家认识什么是字典&字典里的增删改查操作哦!好好听讲哦各位!!!

(1)如何创建并访问字典

①创建字典:

在我们的Python程序设计中,字典可以存储任意类型对象。字典的每个键值“key:value”对之间必须用冒号“:”分割,每个键值对之间用逗号“,”分隔,整个字典包括在大括号“{}”中。

干讲定义过于晦涩难懂,所以老师下面给大家举个粟子:
假如咱们班的Python期末考试成绩公布了,其中第一名小红同学成绩非常优秀,我们学习准备给予奖励。下面我们使用字典保存小红同学的3科成绩,第一个键值对是“线代”:“99”,表示小红同学的线代成绩是“99”;第二个键值对是“数据分析”:“98”,第三个键值对是“概率论”:“99”,分别表示小红同学的数据分析成绩是98,概率论成绩是99。上代码:

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}

当然我们也可以对上述字典中的两个键值对进行分解,通过如下代码创建字典:

dict1 = {'线代': "99"}
dict2 = {"数据分析": "99"}
dict3 = {"概率论": "98"}
知识补给站:
如何创建一个空字典?
a = {}

在这里插入图片描述

两个拓展操作——教你如何快速创建一个字典!

第一个:使用dict()函数创建字典!
同学们是不是感觉上面那种创建字典的方式B格不够,那么老师接下来为大家介绍一种使用函数创建字典的方法:

dict语法:
class dict(**kwarg)
class dict(mapping, **kwarg)
class dict(iterable, **kwarg)

# dict函数作用:通过其他映射(比如其他字典)或者(键,值)对的序列建立字典。
dict1 = dict(a='a', b='b', t='t')     # 传入关键字
print(dict1)

dict2 = dict(zip(['one', 'two', 'three'], [1, 2, 3]))   # 映射函数方式来构造字典
print(dict2)

dict3 = dict([('one', 1), ('two', 2), ('three', 3)])    # 可迭代对象方式来构造字典
print(dict3)

在这里插入图片描述

重点: 使用dict()函数,dict值必须一一对应。
      使用dict()函数,必须每个元组里的成比例。才能将元组转成 key:value

第二个:使用fromkeys()函数创建字典!

语法:
dict.fromkeys(seq[, value])

参数:
seq -- 字典键值列表。
value -- 可选参数, 设置键序列(seq)的值。

返回值:
该方法返回一个新字典。

fromkeys() 函数用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。

上代码:

dict3 = dict.fromkeys(['name','age'])
print(dict3)

dict4 = dict.fromkeys(['name','age'],10)
print(dict4)

在这里插入图片描述需要注意的是:
fromkeys 方法只用来创建新字典,不负责保存。当通过一个字典来调用 fromkeys 方法时,如果需要后续使用一定记得给他复制给其他的变量。

②访问字典:

第一阶段:基操勿6!

如果要想获取字典中某个键的值,可以通过访问键的方式来显示对应的值。上代码:

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}      # 创建字典


print('小红同学的线代成绩是:',dict['线代'])                  # 输出线代成绩
print('小红同学的线代成绩是:',dict['数据分析'])               # 输出数据分析成绩
print('小红同学的线代成绩是:',dict['概率论'])                # 输出概率论成绩

在这里插入图片描述

第二阶段:项目常用!

(1) get 获取指定key 对应的value,如果key不存在返回none——语法:字典名.get(key)
上代码:

a = {'干干': 11, 'age': 11}
print(a.get('age'))

在这里插入图片描述

(2)keys 取出所有的key——用法:字典名.keys()
上代码:

a = {'干干': 11, 'age': 11}
print(a.keys())

在这里插入图片描述(3)values 取出所有的值——用法:字典名.values()
上代码:

a = {'干干': 11, 'age': 11}
print(a.values())

在这里插入图片描述
(4) items 取出所有的键值对——用法:字典名.items()

上代码:

a = {'干干': 11, 'age': 11}
print(a.items())

在这里插入图片描述
(5)setdefault(key) 有此键则查,无则增!
上代码:

di2 = {'name':'干干','age':18,'sex':'男'}
print(di2.setdefault('name'))
di2.setdefault('name2')
print(di2)

在这里插入图片描述

同学们是不是发现——此字典(python程序中的字典)确实非彼字典(《新华字典》),不过确实有那么些共同之处呢!比如:我们查字典的时候,就是查某个字,然后会查出来这个字对应的含义及例词一系列信息;而我们现在用的这个字典,如果我们想要查某个键的值,也是通过查键的方式来显示对应的值呢!大家好好深入思考思考哦!

拓展:如果我们要查某一个键对应的值,而这个键值对在字典中不存在会怎么样呢!

答案显而易见——肯定在执行后会报错,但是我们就是要来看看这会报的什么类型的错!就是倔!!!

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}      # 创建字典

print("dict['语文成绩']:",dict['语文成绩'])

在这里插入图片描述

(2)如何添加,修改,删除字典中的元素

知识补给站:
在python程序中——键是唯一的,但是值可以重复!

①字典中添加数据:

(1)基操勿6!

同学们需要了解的是——在Python程序中,字典是一种动态结构,可以随时在其中添加“键值”对。

具体的在字典中添加数据的操作是:
首先指定字典名,然后用中括号将键括起来,最后写明这个键的值。

我们使用此方法给我们的小红同学的数学和英语成绩也添加上去:

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}      # 创建字典

dict['数学'] = 100        # 添加字典1
dict['英语'] = 99         # 添加字典2

print(dict)               # 输出字典dict中的值
print('小红同学的数学成绩是:',dict['数学'])     # 显示数学成绩

在这里插入图片描述

注意注意注意:
“键值”对的排列顺序与添加顺序不同。因为python不关心键值对的添加顺序,而只关心键和值之间的关联关系!!!

②修改字典:

(1)基操勿6!

**首先指定字典名,然后使用中括号把要修改的键和新值对应起来。**眼睛亮的同学是不是发现这和字典中添加数据好像一样呢!其实可以很肯定的告诉大家,确实是完全一模一样的,所以可以总结出一句顺口溜:有这个键则修改,无则添加!

老师突然发现——我在给小红同学批改线代试卷的时候有个地方批改错了,她应该是100分的,所以我们现在要来修改字典中小红的线代成绩为100分。上代码:

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}      # 创建字典

dict['线代'] = 100

print('小红同学真正的线代成绩是:',dict['线代'])
print(dict)

在这里插入图片描述

(2)项目常用!

** update 更新字典、将原字典和新字典整合,key重复的话则新的覆盖老的!**
上代码:

dict = {'name':'干干','age':18,'sex':'男'}
dict.update({'height': 195, 'age': 20})
print(dict)

在这里插入图片描述

③删除字典中的数据:

(1)基操勿6!

在Python程序中,对于字典中不再需要的信息,可以使用del语句将相应的“键值”对信息彻底删除。
具体操作:
在使用del语句删除字典中数据时,必须指定字典名和要删除的键。

现在我们不需要统计小红同学的线代成绩了,看看我如何将这个键值对删除。上代码:

dict = {'线代': "99", "数据分析": "99", "概率论": "98"}      # 创建字典

del dict['线代']      # 删除键 '线代'
    
print(dict)           # 显示字典dict中的元素

在这里插入图片描述

(2)项目常用!

(1)clear 清空字典——用法:字典名.clear()
上代码:

dict = {'name':'干干','age':18,'sex':'男'}
dict.clear()
print(dict)

在这里插入图片描述
(2) pop 弹出指定key的键值对——用法:字典名.pop(key)

上代码:

dict = {'name':'干干','age':18,'sex':'男'}
a = dict.pop('name')
print('弹出的键对应的值为:', a)
print(dict)

在这里插入图片描述(3) popitem 返回并删除字典中的最后一对键和值——用法:字典名.popitem()
上代码:

dict = {'name':'干干','age':18,'sex':'男'}
a = dict.popitem()		# #相当于栈出,不过每次出的是一个键值对

print('删除字典中最后一对键值对:',a)
print(dict)

在这里插入图片描述

第二小节课 之 字典的骚操作(项目常用!):

①一键多值字典

在Python程序中,可以创建将某个键映射到多个值的字典,即一键多值字典[multidict]。
具体操作:
为了能方便地创建映射多个值的字典,可以使用内置模块collections中的defaultdict()函数来实现。(这个函数一个主要特点是当所访问的键不存在的时候,可以实例化一个值作为默认值,也就是说我们在使用这个函数创建字典时就只需要关注添加元素即可。)

比如如下字典d和e就是两种典型的一键多值字典,那么,如何使用defaultdict()函数来实现呢?
d = {
    'a': [1, 2, 3],
}

e = {
    'a': {1, 2, 3},
}

上代码:

from collections import defaultdict
d = defaultdict(list)
d['a'].append(1)
d['a'].append(2)
d['a'].append(3)
print(d)
print(d['a'])		# 字典中的查操作依旧同我们第一小节课讲的那样。


d = defaultdict(set)
d['a'].add(1)
d['a'].add(2)
d['a'].add(3)
print(d)

在这里插入图片描述但是,我们使用函数defaultdict()会自动创建字典表项以待后面使用。如果不想要这个功能的话,老师现在再教你们一种新的方法:
我们可以在普通的字典上调用函数setdefault()来取代此处用的defaultdict()函数。

上代码:

d = {}
d.setdefault('a', []).append(1)
d.setdefault('a', []).append(2)
d.setdefault('b', []).append(3)
print(d)

在这里插入图片描述

知识补给站:

dict =defaultdict( factory_function)		# defaultdict接受一个工厂函数作为参数

这个factory_function可以是list,str,set,int,作用是当字典里的key不存在但被查找时,返回的不是keyError而是一个默认值(工厂函数的默认值),而这个默认值分别为:list对应[ ],str对应的是空字符串,set对应set( ),int对应0,

from collections import defaultdict

dict1 = defaultdict(int)
dict2 = defaultdict(set)
dict3 = defaultdict(str)
dict4 = defaultdict(list)
dict1[2] = 'nice'		#无则增!

# 这样会正常显示dict1字典里key为2对应的value。
print(dict1[2])

# 我们访问的是通过defaultdict()函数创建的四个字典的key为1对应的值,
# 但是这个key在这四个字典中都并不存在哦,所以返回相应的默认值!
print(dict1[1])		
print(dict2[1])
print(dict3[1])
print(dict4[1])

# 输出:
nice
0
set()

[]
知识补给站升级:
该函数除了接受类型名称作为初始化函数的参数之外,还可以使用任何不带参数的可调用函数,到时该函数的返回值则作为默认值,这样使得默认值的取值更加灵活。下面用一个例子来说明,如何用自定义的不带参数的函数zero()作为初始化函数的参数:

from collections import defaultdict
def zero():
	return 0
dict = defaultdict(zero)
print(dict)

print(dict['first'])

print(dict)

在这里插入图片描述

②获取字典中的最大值和最小值

在Python程序中,我们可以对字典中的数据执行各种数学运算,比如:求最大值,最小值和排序等。为了能对字典中的内容实现有用的计算操作,通过会利用内置函数zip()将字典的键和值反转过来。而对字典中的数据进行排序操作——可以利用函数zip()和sorted()实现。

知识补给站:
函数zip()可以将可迭代对象作为参数,将对象中对应的元素打包成一个元组,然后返回
由这些元组组成的列表。如果各个迭代器的元素个数不一致,则返回的列表长度与最短对
象的相同。利用星号“*”操作符,可以将元组解压为列表

单星号“*”操作符详解!

函数zip()语法格式:

zip([iterable,...]

参数:
iterable表示一个或多个迭代器。

项目实战演示如何分别获取字典中最大值和最小值——上代码:

price = {
    '小米': 899,
    '华为': 1999,
    '三星': 3999,
    '谷歌': 4999,
    '酷派': 599,
    'iPhone': 5000,
}

min_price = min(zip(price.values(), price.keys()))		# 获取字典中手机价格最小的手机
print(min_price)

max_price = max(zip(price.values(), price.keys()))		# 获取字典中手机价格最大的手机
print(max_price)

price_sorted = sorted(zip(price.values(), price.keys()))	# 将字典中手机按价格从低到高排序
print(price_sorted)

在这里插入图片描述

需要注意的是:
我们使用zip()函数创建的是一个迭代器,所以其产生的数据只能被消耗一次,如果二次使用就会报错!如下:
price = {
    '小米': 899,
    '华为': 1999,
    '三星': 3999,
    '谷歌': 4999,
    '酷派': 599,
    'iPhone': 5000,
}

price_and_names = zip(price.values(), price.keys())
print((min(price_and_names)))

print (max(price_and_names))  # 报错error  zip()创建了迭代器,内容只能被消费一次

在这里插入图片描述
如果有时候我们的需求是单独获取字典中最大值/最小值的键和值,那么我们又该怎么做呢?

price = {
    '小米': 899,
    '华为': 1999,
    '三星': 3999,
    '谷歌': 4999,
    '酷派': 599,
    'iPhone': 5000,
}

# 这种直接使用min()和max()函数明显不对哦!这就是按key排序了!
print(min(price))
print(max(price))

print(min(price.values()))
print(max(price.values()))

print(min(price, key=lambda k: price[k]))
print(max(price, key=lambda k: price[k]))

在这里插入图片描述

③使用字典推导式

字典推导式和列表推导式的用法类似,只是将列表中的中括号修改为字典中的大括号而已。

项目实战一:使用字典推导式实现合并大小写key!
上代码:

mcase = {'a': 10, 'b': 34, 'A': 7, 'Z': 3}
mcase_frequency = {
    k.lower(): mcase.get(k.lower(), 0) + mcase.get(k.upper(), 0)
    for k in mcase.keys()
    if k.lower() in ['a','b']
}
print (mcase_frequency)

在这里插入图片描述
项目实战二:使用字典推导式快速更换字典中key和value的值!
上代码:

dict = {'a': 10, 'b': 34}
dict_end = {v: k for k, v in dict.items()}
print(dict_end)

在这里插入图片描述
项目实战三:使用字典推导式从字典中提取子集!
上代码:

prices = {'ASP.NET': 49.9, 'Python': 69.9, 'Java'以上是关于热榜!万字长文第二篇:深入讲解python中一大数据结构之字典(叮叮当~小葵花课堂开课啦!)的主要内容,如果未能解决你的问题,请参考以下文章

万字长文第三篇:深入讲解python中一大数据结构之元组(叮叮当~小葵花课堂开课啦!)

万字长文第三篇:深入讲解python中一大数据结构之元组(叮叮当~小葵花课堂开课啦!)

❤ C站最全Python库总结丨标准库+高级库(万字长文,建议收藏)

万字长文!深入剖析HashMap

各阶段开发人员必备!深入理解Linux系统管理(万字长文)

万字长文告诉新手如何学习Python图像处理(上篇完结 四十四) | 「Python」有奖征文