python学习——【第六弹】
创始人
2025-05-29 18:09:10

前言

上一篇文章 python学习——【第五弹】中我们了解了python中的不可变序列元组,这篇文章接着介绍可变序列 字典

字典

字典的实现原理: 字典,顾名思义其实现原理和字典类似,字典中的元素都是key—value,以键值对的方式存储数据,因此python中的字典可以根据key来查找value的位置。并且字典中的key是唯一的不允许重复,但value是可以重复的。

字典的特点

1:字典是python的内置数据结构之一,是可变序列,并且可以任意嵌套,在原处的增删改等操作不会影响其id地址

2:字典属于无序序列,其每一项都是从左到右随机排序的,即保存在字典中的项是没有固定顺序的,因此无法在字典中指定位置插入元素

3:字典中的key必须是不可变对象,如字符串,元组,数值

4:字典也可以根据需要进行动态伸缩,但会浪费较大的内存,是一种空间换时间的数据结构

创建方式

1:创建字典最常用的方式就是使用花括号:
dict_name = {‘key_1’: ‘value_1’, ‘key_2’: ‘value_2’}

2:使用内置函数dict():
dict_name = dict(‘key_1’=‘value_1’, ‘key_2’=‘value_2’)

使用花括号创建字典:

scores={'join':100,'lisa':102,'tom':99}  #不使用内置函数dict()创建字典时,如果使用字符串作为键,需要在字符串两端加引号
print(scores,type(scores))
#{'join': 100, 'lisa': 102, 'tom': 99} 

使用内置函数dict()创建字典:

scores1=dict(name='tom',age=20)   
print(scores1,type(scores1))
#{'name': 'tom', 'age': 20} 

使用内置函数dict()创建字典时,若字符串作为键,不可在两端加引号。

在这里插入图片描述
空字典的创建:

list1=[1,2,3,4]
dict1={}
dict2=dict()
dict3=dict.fromkeys(list1)
#使用fromkeys()函数需要传入一个列表,使其中元素作为新字典的键,由于没有传值,因此字典值为空。
print(dict1,type(dict1),dict1.values())#{}  dict_values([])
print(dict2,type(dict2))#{} 
print(dict3,type(dict3),dict3.values())#{1: None, 2: None, 3: None, 4: None}  dict_values([None, None, None, None])
any()可以检查字典的值是否为空,为空返回False
print(any(dict1.values()))# False
print(any(dict3.values()))# False

使用元组和列表创建字典:

yuanzu=(11,'aa',22,'bb')
list1=['cc',33,'dd',55]
new_dict={yuanzu:list1} 
print('元组和列表创建字典:', new_dict,type(new_dict))
#元组和列表创建字典: {(11, 'aa', 22, 'bb'): ['cc', 33, 'dd', 55]} 

注意要将元组作为键,列表作为值才能创建字典;若将列表作为键,元组作为值会抛出TypeError的错误,因为字典中的key必须是不可变对象,如字符串,元组,数值

如果想让两个列表创建字典,需要借助zip()函数
使用zip()函数:

items = ['aiai', 'lili', 'nini']  
prices = [10, 20, 30]
d = {item: price for item, price in zip(items, prices)}
print(d, type(d))  # {'aiai': 10, 'lili': 20, 'nini': 30} 
c = {item.upper(): price for item, price in zip(items, prices)}
print(c, type(c))  # {'AIAI': 10, 'LILI': 20, 'NINI': 30} 

或者是直接使用新生成的zip对象生成字典

zip( ) 函数的第一个参数形成了字典中的键 (key),第二个参数形成了字典中的值 (value)。若zip( )中两列表长度不相同,则返回对象与最短列表的长度相同

list1=[1, 2, 3, 4]
list2=['a', 'b', 'c', 'd','p']
new_list=zip(list1, list2)#将list1和list2拼接后转换成zip对象
dictionary=dict(new_list)#将zip对象转换成字典
print(dictionary, type(dictionary))  # {1: 'a', 2: 'b', 3: 'c', 4: 'd'} 

字典元素获取方式

​1: []方法 举例: dict_name[‘key’]

2: get()方法 举例: dict_name.get(‘key’)

两者取值的区别

[]方法:如果字典中不存在指定的key, 抛出keyError异常

get()方法:如果字典中不存在指定的key,
不会抛出keyError的异常,而是返回None,并且可以通过参数设置默认的value,以便指定的key不存在时返回​。

scores={'join':100,'lisa':102,'tom':99}
# print('scores中的om:',scores['om']) # scores['om']  输出 KeyError: 'om'
print('scores中的tom:',scores['tom'])  #scores中的tom: 99
print('scores中的susan:',scores.get('susan'))  # None
print('scores中不存在的元素:',scores.get('lili',99))  #输出99  在字典中所在位置查找的元素不存在时默认输出指定位置的索引

字典中的key

key的判断:

in --》‘kay’ in dict_name —》 指定的key在字典中返回True,不存在返回False

not in —》‘kay’ not in dict_name --》指定的key在字典中不存在返回True,存在返回False

dire1={'lili':1,'kaka':23,'lala':99,'didi':10}
print('lili' in dire1)  #True
print('lili' not in dire1) #False

获取字典中的键、值

dire1={'lili':10,'lisa':11,'kaka':12}
key1=dire1.keys()
print(key1) #dict_keys(['lili', 'lisa', 'kaka'])
print(type(key1)) # 
print(list(key1))  #将所有的key组成的视图转成列表  ['lili', 'lisa', 'kaka']
print(tuple(key1)) #将所有的key组成的视图转成元组  ('lili', 'lisa', 'kaka')
print(set(key1))#将所有的key组成的视图转成集合 {'lili', 'kaka', 'lisa'}
#获取所有的value
dire1={'lili':10,'lisa':11,'kaka':12}
value1=dire1.values()
print(value1) #dict_values([10, 11, 12])
print(type(value1)) #
print(list(value1))  #将所有的value值组成的视图转换成列表[10, 11, 12]
print(tuple(value1))  #将所有的value值组成的视图转换成元组(10, 11, 12)
print(set(value1))    #将所有的value值组成的视图转换成集合{10, 11, 12}
# 获取所有的key-value对
dire1={'lili':10,'lisa':11,'kaka':12}
items=dire1.items()
print(items) #dict_items([('lili', 10), ('lisa', 11), ('kaka', 12)])
print(list(items)) #[('lili', 10), ('lisa', 11), ('kaka', 12)]  转换之后的列表元素是由元组组成的# 根据相同的值来获取不同的键
dicts={'Math':100,'Chinese':100,'Engish':90}
keys=[k for k,v in dicts.items() if v==100]
print('值为100的键有:',keys)  #值为100的键有: ['Math', 'Chinese']

字典元素的遍历

使用键值对遍历

dire1={'lili':11,'lala':22,'caca':23}
for item in  dire1.items():print(item)
'''
('lili', 11)
('lala', 22)
('caca', 23)
'''
dire1={'lili':11,'lala':22,'caca':23}
for key,value in dire1.items():print(key,"的年龄是:",value)
'''
lili 的年龄是: 11
lala 的年龄是: 22
caca 的年龄是: 23
'''

遍历字典的键:

dire1={'lili':11,'lala':22,'caca':23}
for keys in dire1.keys():print(keys)
'''
lili
lala
caca
'''

遍历字典的值:

dire1={'lili':11,'lala':22,'caca':23}
for values in dire1.values():print(values)
'''
11
22
23
''' 

向字典中增加元素

dire2={'cici':12,'dodo':13,'cici':11,'qiqi':10}
print('新增前dire2的字典:',dire2,id(dire2))  #增加前dire2的字典: {'cici': 11, 'dodo': 13, 'qiqi': 10} 140215317019616
dire2['kiki']=20 #默认再字典元素末尾新增一个元素
print('新增元素后的字典:',dire2,id(dire2))  #增加元素后的字典: {'cici': 11, 'dodo': 13, 'qiqi': 10, 'kiki': 20} 140215317019616

给字典删除元素

dire1={'lili':1,'kaka':23,'lala':99,'didi':10}
print('删除前dire1字典:',dire1,id(dire1))  #删除前dire1字典: {'lili': 1, 'kaka': 23, 'lala': 99, 'didi': 10} 140215317019536
del dire1['lili']
print('删除指定元素后的dire1字典:',dire1,id(dire1))#删除指定元素后的dire1字典: {'kaka': 23, 'lala': 99, 'didi': 10} 140215317019536

修改字典中的元素

# 修改字典相应键的值
dire2={'cici':12,'dodo':13,'cici':11,'qiqi':10}
dire2['cici']=55
print('修改值后的字典:',dire2)  #修改值后的字典: {'cici': 55, 'dodo': 13, 'qiqi': 10, 'kiki': 20}

每篇一语

工欲善其事,必先利其器!
如有不足,感谢指正!

相关内容

热门资讯

网红咖啡的审美狂欢下,我们是否... 上周,我被一个朋友神秘兮兮地拉进一个线上咖啡群。 群里每天热火朝天的,不是讨论耶加雪菲的水洗和日晒在...
原创 这... 在春节这个充满喜庆与团聚的节日里,挑选一款合适的红酒来增添宴席的格调,无疑是一件令人愉悦的事情。然而...
督皇口粮酱酒独特的风味与文化底... 督皇口粮酱酒以其丰富的文化底蕴和独特的风味吸引了众多消费者。该酒在选材上精挑细选,采用优质的高粱和小...
原创 3... 标题:3分钟教你做紫薯面包,甜而不腻,香气四溢,大人孩子都爱吃 在这个快节奏的时代,我们总是在寻找...
AI截流时代:张家界莓茶如何用... 在刚刚过去的2025年,中国AI搜索用户规模已突破5亿。 当年轻消费者习惯在抖音上“发现”好物,在D...