python 字典相关操作

字典

字典的增删改查

字典的创建方式:

# 创建字典类型
info = {
    ‘name‘:‘李白‘,
    ‘age‘:‘25‘,
    ‘sex‘:‘男‘
}

msg = {
    ‘user01‘:‘Longzeluola‘,
    ‘user02‘:‘xiaozemaliya‘,
    ‘user03‘:‘cangjingkong‘
}

字典存储数据的时候,采取的是key:value的形式,是一组无序的存储。在需要的时候通过key就能够快速的获取value。

msg = {
    ‘user01‘:‘Longzeluola‘,
    ‘user02‘:‘xiaozemaliya‘,
    ‘user03‘:‘cangjingkong‘
}

print(msg[‘user01‘])  # Longzeluola

字典的值可以根据key值获取并且进行更改。

msg = {
    ‘user01‘:‘Longzeluola‘,
    ‘user02‘:‘xiaozemaliya‘,
    ‘user03‘:‘cangjingkong‘
}

msg[‘user03‘] = ‘泷泽萝拉‘

结果:

{‘user01‘: ‘Longzeluola‘, ‘user02‘: ‘xiaozemaliya‘, ‘user03‘: ‘泷泽萝拉‘}

那么字典中如果需要新添加数据的话,也可以通过设置key-value的形式来进行添加。

msg = {
    ‘user01‘:‘Longzeluola‘,
    ‘user02‘:‘xiaozemaliya‘,
    ‘user03‘:‘cangjingkong‘
}

msg[‘user04‘] = ‘MaLiCang‘
print(msg)

结果:

{‘user01‘: ‘Longzeluola‘, ‘user02‘: ‘xiaozemaliya‘, ‘user03‘: ‘cangjingkong‘, ‘user04‘: ‘MaLiCang‘}

而如果需要删除python中的数据,可以使用如下的三种方法:

msg = {
    ‘user01‘:‘Longzeluola‘,
    ‘user02‘:‘xiaozemaliya‘,
    ‘user03‘:‘cangjingkong‘
}

# 删除字典方法一
#del msg[‘user01‘]  # {‘user02‘: ‘xiaozemaliya‘, ‘user03‘: ‘cangjingkong‘}

# 删除字典方法二
#msg.pop(‘user01‘)  # # {‘user02‘: ‘xiaozemaliya‘, ‘user03‘: ‘cangjingkong‘}

# 删除字典方法三
msg.popitem() # {‘user01‘: ‘Longzeluola‘, ‘user02‘: ‘xiaozemaliya‘}

补充

在上面的一些操作中,我们基本实现了字典的增删改查,但是在查的过程中,有一点是需要注意的,如上面的查询方式dir[key]这种,如果key值并不存在于字典中,就会出现一个keyerror的错误,所以为了避免错误,我们通常情况下都不会使用这种方式来进行字典的key值查找,而是通过下面的方法。

# 创建一个字典

msg = {
    ‘user1101‘:‘Xiaozemaliya‘,
    ‘user1102‘:‘Wutentlan‘,
    ‘user1103‘:‘Cangjingkong‘
}

# 通过key值获取value 使用get方式,存在key,那么就返回对应的value,如果不存在key,那么就返回None
print(msg.get(‘user1101‘)) # Xiaozemaliya
print(msg.get(‘user1108‘)) # None 

判断一个key是否存在于一个字典中,可以使用in 运算符。

# 创建一个字典

msg = {
    ‘user1101‘:‘Xiaozemaliya‘,
    ‘user1102‘:‘Wutentlan‘,
    ‘user1103‘:‘Cangjingkong‘
}

# 使用in检测字典中是否存在指定的key
print(‘user1101‘ in msg) # True
print(‘user1109‘ in msg) # False

上面是使用in运算符判断key是否存在,需要注意的是,在python2.x 的版本中,判断一个key是否存在于字典中,可以使用msg.has_key()的方式来进行判断。

多级字典嵌套及操作

在字典中,一直以key-value的形式进行数据存储,但是value的值除了是字符串以外,还可以是其他类型的值。同时,在字典中,也可以继续嵌套字典等数据。具体操作如下:

# 创建一个多级的字典
av_catalog = {
    "欧美":{
        "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
        "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
        "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
        "x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]
    },
    "日韩":{
        "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]
    },
    "大陆":{
        "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
    }
}

# 更改key值
av_catalog[‘大陆‘][‘1024‘][1] = ‘可以在国内做一个镜像‘

print(av_catalog)

关于字典的补充说明

values 打印字典里面的所有的值

msg = {
    ‘stu1101‘:‘XiaomingStudent‘,
    ‘stu1102‘:‘XiaohongStudent‘,
    ‘stu2201‘:‘XiaolvStudent‘,
    ‘stu3101‘:‘XiaoZhangStudent‘
}
# values() 方法 输出字典中所有的值
print(msg.values())

结果为:

dict_values([‘XiaomingStudent‘, ‘XiaohongStudent‘, ‘XiaolvStudent‘, ‘XiaoZhangStudent‘])

keys 打印所有的key

msg = {
    ‘stu1101‘:‘XiaomingStudent‘,
    ‘stu1102‘:‘XiaohongStudent‘,
    ‘stu2201‘:‘XiaolvStudent‘,
    ‘stu3101‘:‘XiaoZhangStudent‘
}

# keys 打印所有的key
print(msg.keys())

结果为:

dict_keys([‘stu1101‘, ‘stu1102‘, ‘stu2201‘, ‘stu3101‘])

setdefault

设置新的key:value ,如果设置的key在字典中存在,那么就会把之前的key以及value返回,新设置的就会失效,如果没有就把设置的key:value添加到字典中去。

msg = {
    ‘stu1101‘:‘XiaomingStudent‘,
    ‘stu1102‘:‘XiaohongStudent‘,
    ‘stu2201‘:‘XiaolvStudent‘,
    ‘stu3101‘:‘XiaoZhangStudent‘
}

# 使用setdefault方法设置key:value
msg.setdefault(‘stu3101‘,‘YanYanStudent‘) # 此时3101key 已经存在,并不会新增的内容所影响
print(msg)
msg.setdefault(‘stu3102‘,‘LuLuStudent‘) # 此时新增加的key 3102 添加成功
print(msg)

update 更新合并

使用update方法,可以将两个字典合并,并且如果字典中存在重复的内容,会产生覆盖,如果内容不重复,就会被合并到一个字典中。

msg = {
    ‘stu1101‘:‘XiaomingStudent‘,
    ‘stu1102‘:‘XiaohongStudent‘,
    ‘stu2201‘:‘XiaolvStudent‘,
    ‘stu3101‘:‘XiaoZhangStudent‘
}

test_info = {
    ‘T1101‘:‘YanYanTeacher‘,
    ‘T1102‘:‘LiBai‘,
    ‘stu2201‘:‘JingjingStudent‘
}

msg.update(test_info)

print(msg)

输出结果为:

{‘stu1101‘: ‘XiaomingStudent‘, ‘stu1102‘: ‘XiaohongStudent‘, ‘stu2201‘: ‘JingjingStudent‘, ‘stu3101‘: ‘XiaoZhangStudent‘, ‘T1101‘: ‘YanYanTeacher‘, ‘T1102‘: ‘LiBai‘}

items 把一个列表转为一个元组

msg = {
    ‘stu1101‘:‘XiaomingStudent‘,
    ‘stu1102‘:‘XiaohongStudent‘,
    ‘stu2201‘:‘XiaolvStudent‘,
    ‘stu3101‘:‘XiaoZhangStudent‘
}

print(msg.items())

输出结果为:

dict_items([(‘stu1101‘, ‘XiaomingStudent‘), (‘stu1102‘, ‘XiaohongStudent‘), (‘stu2201‘, ‘XiaolvStudent‘), (‘stu3101‘, ‘XiaoZhangStudent‘)])

fromkeys 创建一个初始化列表

test_dir = dict.fromkeys([‘stu01‘,‘stu02‘,‘stu03‘],[1,{‘name‘:‘YanYanStudent‘}])

print(test_dir) 

输出的结果为:

{‘stu01‘: [1, {‘name‘: ‘YanYanStudent‘}], ‘stu02‘: [1, {‘name‘: ‘YanYanStudent‘}], ‘stu03‘: [1, {‘name‘: ‘YanYanStudent‘}]}

此时通过dict.fromkeys方法,就创建出了一个新的字典,但是在这个字典中存在一个容易错的地方,如下:

test_dir = dict.fromkeys([‘stu01‘,‘stu02‘,‘stu03‘],[1,{‘name‘:‘YanYanStudent‘}])

# 尝试着更改这个字典中的内容通过key值
test_dir[‘stu01‘][1][‘name‘] = ‘YanYanTeacher‘

print(test_dir)

我们在代码中更改了其中的一个key的值,结果输出却为:

{‘stu01‘: [1, {‘name‘: ‘YanYanTeacher‘}], ‘stu02‘: [1, {‘name‘: ‘YanYanTeacher‘}], ‘stu03‘: [1, {‘name‘: ‘YanYanTeacher‘}]}

此时我们发现所有的key对应的value都被改变了。而这也是我们在使用这个fromkeys方法的时候需要注意的点。

字典的循环输出

将字典中key和value循环输出,有以下的两种方式:

# 创建一个字典
msg = {
    ‘T1101‘:‘YanYanTeacher‘,
    ‘T1201‘:‘LuLuTeacher‘,
    ‘T1301‘:‘JingJingTeacher‘
}

# 循环输出字典 -- 第一种方法
for i in msg:
    print(i,msg[i])

# 循环输出字典 -- 第二种方法
for i,v in msg.items():
    print(i,v)

上面两种循环输出列表的方式输出的结果是一样的,但是较为推荐使用第一种,因为第一种方式的执行效率要高于第二种,因为第一种是直接根据key值取出value,而第二种方式则是要多出一步将字典转换为列表的步骤,所以效率相对来讲比较低。

时间: 2024-10-24 04:05:44

python 字典相关操作的相关文章

Python字典增删操作技巧简述

Python编程语言是一款比较容易学习的计算机通用型语言.对于初学者来说,首先需要掌握的就是其中的一些基础应用.比如今天我们为大家介绍的Python字典的相关操作,就是我们在学习过程中需要熟练掌握的技巧. Python字典(Dictionary)是一种映射结构的数据类型,由无序的“键-值对”组成.字典的键必须是不可改变的类型,如:字符串,数字,tuple:值可以为任何Python数据类型. 1.新建Python字典 >>> dict = {} #新建一个空字典 >>>

python文件相关操作

Python文件相关操作 打开文件 打开文件,采用open方法,会将文件的句柄返回,如下: f = open('test_file.txt','r',encoding='utf-8') 在上面的代码中,open()方法进行打开文件等相关操作,open()方法其中第一个参数是要打开的文件的文件路径,第二个参数是对要打开文件要执行的权限,第三个参数是文件采用字符编码. 而open()方法返回的内容叫做文件句柄.我们可以打印返回的文件句柄来看下: f = open('test_file.txt','r

python集合相关操作

集合相关操作 集合是一个无序的,不重复的数据组合,它有着两个主要作用:去重以及关系测试. 去重指的是当把一个列表变成了集合,其中重复的内容就自动的被去掉了 关系测试指的是,测试两组数据之间的交集.差集.并集等关系. 去重测试代码如下: # 创建一个列表 -- 里面存在一些重复值 test_list = [1,2,3,4,2,2,3,4,3,2,3,4] # 利用集合将列表中重复的内容去掉 test_list = set(test_list) # 打印测试并且查看test_list 被赋予新值后的

python 集合相关操作

集合相关操作 集合是一个无序的,不重复的数据组合,它有着两个主要作用:去重以及关系测试. 去重指的是当把一个列表变成了集合,其中重复的内容就自动的被去掉了 关系测试指的是,测试两组数据之间的交集.差集.并集等关系. 去重测试代码如下: # 创建一个列表 -- 里面存在一些重复值 test_list = [1,2,3,4,2,2,3,4,3,2,3,4] # 利用集合将列表中重复的内容去掉 test_list = set(test_list) # 打印测试并且查看test_list 被赋予新值后的

【python】Python 字典(Dictionary)操作详解

Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型.一.创建字典字典由键和对应值成对组成.字典也被称作关联数组或哈希表.基本语法如下: dict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'} 也可如此创建字典: dict1 = { 'abc': 456 }; dict2 = { 'abc': 123, 98.6: 37 }; 注意:每个键与值用冒号隔开(:),每对用逗号,每对用逗号分割,整体放

python PIL相关操作

项目中需要用python生成二维码,这里记录一下相关PIL相关操作. RGBA问题: 需要将图片A粘贴到图片B上,之前没有注意透明度问题,A的背景是透明的,粘贴到B上后,A的周围是黑的.后来才发现是PIL的Image模块,调用open打开文件以后,需要convert转换为'RGBA'模式,R:red G:green B:blue A:Alpha 色彩空间 透明度,设置一下图片的透明度即可. 图片的粘贴,文字的添加需要调用ImageDraw模块,首先打开背景图 img = Image.open('

Python 字典(Dictionary)操作详解

Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型.一.创建字典 字典由键和对应值成对组成.字典也被称作关联数组或哈希表.基本语法如下: dict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'} 也可如此创建字典 dict1 = { 'abc': 456 } dict2 = { 'abc': 123, 98.6: 37 } 注意:每个键与值用冒号隔开(:),每对用逗号,每对用逗号分割,整体放在花

Python字典的操作与使用

字典的描述 字典是一种key-value的数据类型,使用就像我们上学用的字典,通过拼音(key)来查对应字的详细内容(value). 字典的特性 1.字典是无序的(不像列表一样有下标,它通过key来获取value) 2.key必须是唯一的,所以天生去重 字典的操作 info = { 'stu1101': "TengLan Wu", 'stu1102': "LongZe Luola", 'stu1103': "XiaoZe Maliya", } 获

python字典的操作

一,字典的操作 a={'name':'wo','age':18} dict.clear()# 删除字典内所有元素 a.clear() dict.copy()#返回一个字典的浅复制 a.copy() dict.get(key, default=None)#返回指定键的值,如果值不在字典中返回default值 a.get('h','123') dict.items() #以列表返回可遍历的(键, 值) 元组数组 print(a.items()) #结果 dict_items([('name', 'w