【Python基础】Python字典详解-超级完整版

本文的目录:

一、字典概述

01 字典的格式

Python字典是一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。

字典的每个键值key=>value对用冒号 : 分割,每个对之间用逗号,分割,整个字典包括在花括号{}中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }

02 字典的创建

有多种方法可以创建字典,以下几种方法创建的字典均等于 {'one': 1, 'two': 2, 'three': 3}

a = dict(one=1, two=2, three=3)b = {'one': 1, 'two': 2, 'three': 3}c = dict(zip(['one', 'two', 'three'], [1, 2, 3]))d = dict([('two', 2), ('one', 1), ('three', 3)])e = dict({'three': 3, 'one': 1, 'two': 2})f = dict({'one': 1, 'three': 3}, two=2)a == b == c == d == e == f

03 字典键的特性

字典可以没有限制地取任何python对象,既可以是标准的对象,也可以是用户定义的,但不行,有特殊的要求,两个重要的点需要记住:

1)唯一性:不允许同一个键出现两次,创建时如果同一个键被赋值两次,后一个值会被记住。

2)不可变:键必须不可变,所以可以用数字,字符串或元组充当,所以用列表、字典等就不行。

04 学习文档

官方文档:https://docs.python.org/zh-cn/3/library/stdtypes.html#mapping-types-dict

二、字典的11个方法

print(dir(dict))['clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']

01 fromkeys()

描述:创建一个新字典,以序列seq 中元素做字典的键,value为字典所有键对应的初始值。

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

参数:

seq 一个序列,作为字典键值列表。

value 可选参数, 设置键序列(seq)的值。

fromkeys是创造一个新的字典。就是事先造好一个空字典和一个列表,fromkeys会接收两个参数,第一个参数为从外部传入的可迭代对象,会将循环取出元素作为字典的key值,另外一个参数是字典的value值,不写所有的key值所对应的value值均为None,写了则为默认的值

#快速生成字典seq = ('Google', 'Baidu', 'Taobao')dict.fromkeys(seq){'Google': None, 'Baidu': None, 'Taobao': None}dict.fromkeys(seq, 1){'Google': 1, 'Baidu': 1, 'Taobao': 1}dict.fromkeys(range(5), 88){0: 88, 1: 88, 2: 88, 3: 88, 4: 88s = [1,2,3]dict.fromkeys(seq,s){'Google': [1, 2, 3], 'Baidu': [1, 2, 3], 'Taobao': [1, 2, 3

02 clear()

描述:清除字典中所有的元素,得到的是空的字典。返回值None

语法:dict.clear()

参数:NA

dic = {'python3':123}print(dic.clear())Nonedef main():    my_dict = {'子': '鼠', '丑': '牛', '寅': '虎', '卯': '兔',               '辰': '龙', '巳': '蛇', '午': '马', '未': '羊',               '申': '猴', '酉': '鸡', '戌': '狗', '亥': '猪'}    print('子' in my_dict.keys())    print('鼠' in my_dict.values())        print('小伍哥' in my_dict.keys())    print('小伍哥' in my_dict.values())    print ('字典长度 : %d' %  len(my_dict))    # 清空字典的指定用法    my_dict.clear()    print(my_dict)    print ('字典删除后长度 : %d' % len(my_dict))if __name__ == '__main__':    main()#运行结果    TrueTrueFalseFalse字典长度 : 12{}字典删除后长度 : 0

03 copy()

描述:返回一个字典浅拷贝的副本

语法:dict.copy()

参数:

dict1 = {'Name': 'Xiaowuge', 'Age': 17};dict2 = dict1.copy()str(dict2)'{'Name': 'Xiaowuge', 'Age': 17}'dict_0  = {'name':'xiaowuge','age':18,'proerty':'shuai'}dict_0{'name': 'xiaowuge', 'age': 18, 'proerty': 'shuai'}dict_1 = dict_0.copy()dict_1{'name': 'xiaowuge', 'age': 18, 'proerty': 'shuai'}dict_0.update({'age':28})dict_0{'name': 'xiaowuge', 'age': 28, 'proerty': 'shuai'}dict_1 {'name': 'xiaowuge', 'age': 18, 'proerty': 'shuai'

注意:python字典的复制、浅拷贝和深拷贝的区别

复   制:跟原字典完全一样

浅拷贝:将原字典拷贝一份,但是没有拷贝原字典中的子对象,所以当原字典中的子对象发生变化时,浅拷贝后的字典也会发生变化

深拷贝:将原字典连同其子对象一块进行了拷贝,所以深拷贝后的字典不会随着原字典的变化而改变

代码示例:

import sysimport copydef main():    d0 = {1:'a', 2:'b', 3:'c', 4:[1,2,3]}    d1 = d0    d2 = d0.copy()    d3 = copy.deepcopy(d0)    print ('d0:', d0)    print ('d1:', d1)    print ('d2:', d2)    print ('d3:', d3)    print ('*'*10, '原字典d0改变后')    d0[1] = 'aa'    d0[4].append(4)     print ('d0:',id(d0),d0)    print ('d1:',id(d1),d1)    print ('d2:',id(d2),d2)    print ('d3:',id(d3),d3)if __name__ == '__main__':    main()          d0: {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3]}d1: {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3]}d2: {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3]}d3: {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3]}********** 原字典d改变后d0: 130346024 {1: 'aa', 2: 'b', 3: 'c', 4: [1, 2, 3, 4]}d1: 130346024 {1: 'aa', 2: 'b', 3: 'c', 4: [1, 2, 3, 4]}d2: 130345944 {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3, 4]}d3: 130346344 {1: 'a', 2: 'b', 3: 'c', 4: [1, 2, 3

可以看到,随着d0的改变, d1完全改变,d2 '4: [1, 2, 3, 4]'发生了改变,d3未发生改变,可以看到,深拷贝不受原字典变更的影响,其他情况下会受到影响。

04 get()

描述:返回指定键的值,如果值不在字典中返回default值

语法:dict.get(key, default=None)

参数:

key -- 字典中要查找的键。

default -- 如果指定键的值不存在时,返回该默认值None。

dic = {'uiui':'ioio'}dic.get('uiui')'ioio'dic.get('uiuiui','我是第二个参数,字典中不存在参数一中的键')'我是第二个参数,字典中不存在参数一中的键'print(dic.get('uiuiui'))None

05 setdefault()

描述:如果键不存在于字典中,将会添加键并将值设为默认值。如果存在,则返回该字段的值,Python字典setdefault() 函数和get()方法类似

语法:dict.setdefault(key, default=None)

参数:

key -- 查找的键值。

default -- 键不存在时,设置的默认键值。

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.setdefault('name')'Alice'print(dict){'name': 'Alice', 'age': 23, 'address': 'Hangzhou'}#身高这个键,看看有没有,没有就加进去dict.setdefault('high',178)178dict{'name': 'Alice', 'age': 23, 'address': 'Hangzhou', 'high': 17}

06 keys()

描述:以列表返回一个字典所有的键。

语法:dict.keys()

参数:

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.keys()dict_keys(['name', 'age', 'address'])list(dict.keys())#转换成列表['name', 'age', 'address']

07 values()

描述:返回字典中所有键对应的值

语法:dict.values()

参数:

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.values()dict_values(['Alice', 23, 'Hangzhou'])dict = {'nick':'帅气小王子','item':'长袖短款','price':29.99,'prov':'杭州'}dict.values()dict_values(['帅气小王子', '长袖短款', 29.99, '杭州'])

08 items()

描述:列表返回可遍历的(键, 值) 元组数组。

语法:dict.items()

参数:

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.items()dict_items([('name', 'Alice'), ('age', 23), ('address', 'Hangzhou')])最终得到的是一个dict_items对象。这个对象也是一个可迭代对象,可以用iter方法将其转化为一个迭代器,其将字典的每一个键值对都转化成了元组dic1 = iter(dict.items())for i in dic1:    print(i)    print(type(i))#同时进行引用循环dict = {'name':'Alice','age':23,'address':'Hangzhou'}for i,v in dict.items():    print(i+':'+str(v))name:Aliceage:23address:Hangzhou   my_dict = {'马  云':'1000亿','马化腾':'900亿','王健林':'800亿'}for i, v in my_dict.items():    print(i+':'+v)马  云:1000亿马化腾:900亿王健林:800亿

09 pop()

描述:顾名思义让字典中的某个键对应的项“离开”字典。

语法:pop(key[,default])

参数:

key: 要删除的键值

default: 如果没有 key,返回 default 值

接受两个参数,第一个参数为键,第二个参数为可选参数,如果字典中不存在第一个参数中的键,

则返回第二个参数。如果没有传入第二个参数,则抛出keyerror。

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.pop('age')23print(dict){'name': 'Alice', 'address': 'Hangzhou'} #age没了

10 popitem()

描述:随机删除字典中某一键值对,并以元组的形式返回这一键值对,返回并删除字典中的最后一对键和值。

语法:dict.popitem()

参数:

注意:pop 和 popitem 是字典中的删除操作。pop 是以字典的 “键” 为参数,删除指定的键 / 值对,pop 中的参数不能省略且如果删除字典中没有的键 / 值对,会报错。

dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.popitem()('address', 'Hangzhou')print(dict){'name': 'Alice', 'age': 23}

11 update()

描述:更新字典的键-值对,将参数中字典中的键值对更新到字典中,此方法无返回值

语法:dict.update(dict)

参数:dict-- 添加到指定字典dict里的字典。

#第一种方式dict = {'name':'Alice','age':23,'address':'Hangzhou'}dict.update({'age':80})print(dict){'name': 'Alice', 'age': 80, 'address': 'Hangzhou'}#第二种方式dict.update(age=180)dict{'name': 'Alice', 'age': 180, 'address': 'Hangzhou'}my_dict = {'马  云':'1000亿','马化腾':'900亿','王健林':'800亿'}my_dict.update(马化腾='1900亿')my_dict{'马  云': '1000亿', '马化腾': '1900亿', '王健林': '800亿'}

三、其他支持

除了上面字典特有的11个方法,这些是字典所支持的操作(自定义的映射类型也应当支持)

01 list(d)

返回字典 d 中使用的所有键的列表。

my_dict = {'one': 1, 'two': 2, 'three': 3}list(my_dict)['one', 'two', 'three']

02 len(d)

返回字典 d 中的项数。

my_dict = {'one': 1, 'two': 2, 'three': 3}len(my_dict)3

03 d[key]

返回 d 中以 key 为键的项。如果映射中不存在 key 则会引发 KeyError。

my_dict['one'] 1

04 d[key] = value

将 d[key] 设为 value。

my_dict['one']=10my_dict{'one': 10, 'two': 2, 'three': 3}

05 del d[key]

将 d[key] 从 d 中移除。如果映射中不存在 key 则会引发 KeyError。

my_dict = {'one': 1, 'two': 2, 'three': 3}del my_dict['one']my_dict{'two': 2, 'three': 3}

06 key in d

如果 d 中存在键 key 则返回 True,否则返回 False。

my_dict = {'one': 1, 'two': 2, 'three': 3}'one' in my_dict True

07 key not in d

等价于 not key in d。

my_dict = {'one': 1, 'two': 2, 'three': 3}'one' not in my_dict False'小伍哥' not in my_dict True

08 iter(d)

返回以字典的键为元素的迭代器。这是 iter(d.keys()) 的快捷方式。

my_dict = {'one': 1, 'two': 2, 'three': 3}iter(my_dict) <dict_keyiterator at 0xce0dbd8>list(iter(my_dict))['one', 'two', 'three']

08 reversed(d)

返回一个逆序获取字典键的迭代器。这是 reversed(d.keys()) 的快捷方式。

3.8 新版功能.

d = {'one': 1, 'two': 2, 'three': 3, 'four': 4}d{'one': 1, 'two': 2, 'three': 3, 'four': 4}
list(reversed(d))['four', 'three', 'two', 'one']
list(reversed(d.values()))[4, 3, 2, 1]
list(reversed(d.items()))[('four', 4), ('three', 3), ('two', 2), ('one', 1)]

09 d | other

合并 d 和 other 中的键和值来创建一个新的字典,两者必须都是字典。当 d 和 other 有相同键时, other 的值优先。

3.9 新版功能.

10 d |= other

用 other 的键和值更新字典 d ,other 可以是 mapping 或 iterable 的键值对。当 d 和 other 有相同键时, other 的值优先。

3.9 新版功能.

(0)

相关推荐

  • python字典

    近些年最长的五一小长假结束了,结束了,结束了...... 来一张照片抚慰一下想出去浪的心...... 字典在python中也是一种常用的数据类型. 它是一种可变容器模型,可用来存储任意类型的对象,如: ...

  • python之dictionary

    python之dictionary

  • Python字典的11个方法超级详解

    Python字典是一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型. print(dir(dict))['clear', 'copy', 'fromkeys', 'get', ...

  • Python基础学习笔记(五)集合与字典

    本节知识大纲: 集合 字典 一.Set 集合的概念 1. set 集合的性质 set 集合是一组无序的且不能重复的集合,打印 set 集合时会自动消除重复的元素项: set 集合用大括号表示: set ...

  • 成功解决AttributeError: ‘dict_values‘ object has no attribute ‘index‘

    成功解决AttributeError: 'dict_values' object has no attribute 'index' 解决问题 AttributeError: 'dict_values' ...

  • 技巧 | Python 字典用法详解(超全)

    原创 欧King Python当打之年 1周前 本期导读 字典(Dictionary)是Python提供的一种常用的数据结构,它用于存放具有映射关系的数据.本期给大家带来Python字典11个方法的全 ...

  • 孙子兵法36计详解(完整版) 永久收藏!

    NO.1 胜战计 第一计 瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太阳,太阴. 译:认为准备万分周到,就容易松劲:平时看惯了的,就往往不在怀疑了,秘计隐藏在暴露的事物中,而不是和公开 ...

  • 孙子兵法36计详解(完整版) 永久收藏

    NO.1 胜战计 第一计 瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太阳,太阴. 译:认为准备万分周到,就容易松劲:平时看惯了的,就往往不在怀疑了,秘计隐藏在暴露的事物中,而不是和公开 ...

  • 《三十六计》详解(完整版) 永久收藏,终生研读!

    <三十六计>是根据我国古代卓越的军事思想和丰富的斗争经验总结而成的兵书,是中华民族悠久文化遗产之一. 第一套 胜战计 1第一计:瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太 ...

  • 国学 | 孙子兵法36计详解(完整版) 永久收藏,终生研读

    第一套 胜战计 第一计.瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太阳,太阴. 译:认为准备万分周到,就容易松劲:平时看惯了的,就往往不在怀疑了,秘计隐藏在暴露的事物中,而不是和公开的 ...

  • 《民法典》十大重大修订详解(完整版)

    文章目次 一.保证制度的变化(P第686条 P第406条 P第530条) 二.抵押权的变化(P第406条) 三.情势变更制度的确立(P第530条 ) 四.违约方解除权(P第580条 ) 五.选择之债( ...

  • 【实用】孙子兵法36计详解(完整版) 永久收藏

    【实用】孙子兵法36计详解(完整版) 永久收藏

  • 玄武山佛祖签诗详解!完整版(请收藏)

    每年的正月是人们来朝拜玄武山佛祖的时间,很多潮汕人,不管在国内和国外,年年如约到来.尤其是初三的晚上更是热闹非凡,诚心拜佛的人人山人海,各种各样的车辆把碣石镇的道路塞得水泄不通.人们到来的目的:一是求 ...

  • 孙子兵法36计详解(完整版)( 永久收藏)

    ​NO.1 胜战计 第一计 瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太阳,太阴.  译:认为准备万分周到,就容易松劲:平时看惯了的,就往往不在怀疑了,秘计隐藏在暴露的事物中,而不是和 ...

  • 《三十六计》详解(完整版)永久收藏,终生研读!

    <三十六计>是根据我国古代卓越的军事思想和丰富的斗争经验总结而成的兵书,是中华民族悠久文化遗产之一. 第一套 胜战计 1第一计:瞒天过海 备周而意怠,常见则不疑,阴在阳之内,不在阳之对.太 ...