Python字典的内置方法

简介:
+关注继续查看

字典由key和value组成,key必须唯一,值可以不唯一。字典是无序的。


字典常用的方法

clear():

清除字典中的所有内容

1
2
3
4
 >>> dic1={"name":"zeng","age":28}       
    >>> dic1.clear()
    >>> dic1
    {}


items()

获取字典的key和value,结果为列表

1
2
3
4
>>> dic
{'liu': 23, 'zhou': 22, 'zeng': 21}
>>> dic.items()
[('liu', 23), ('zhou', 22), ('zeng', 21)]



get():

获取字典中指定key对应的值。与dic[‘key’]作用一样,但不同的是,如果key不存在不会报错,返回的是None 

1
2
3
>>> dic={'k1':1234}
>>> dic.get('k1')
1234

如果希望key不存在时,返回自定义的值,可以这样

1
2
>>> dic.get('k2','ok')
'ok'


字典赋值

1
2
3
>>> dic['k2']=4567
>>> dic
{'k2': 4567, 'k1': 1234}



 判断是否为字典

1
2
>>> type(dic) is dict
True



fromkeys(list,value):  

用列表中的每一个值当做key,后面的值当做value,生成一个字典  

1
2
3
>>> a={}
>>> a.fromkeys(['zeng','zhou','liu'],'Defensor')
{'liu''Defensor''zhou''Defensor''zeng': ‘Defensor'}


has_key(k):

检查字典中是否指定的key,也可以用 "key in dict" 来判断

1
2
3
4
5
6
>>> b
{'liu''Defensor''zhou''Defensor''zeng''Defensor'}
>>> b.has_key('zeng')
True
>>> "liu" in b
True



keys():打印字典中所有的key

pop(k):删除指定的键值对, 并打印出删除的值

1
2
3
4
>>> b
{'liu''Defensor''zhou''Defensor''zeng''Defensor'}
>>> b.pop('liu')
‘Defensor'

  

字典的循环和取值

第一种方法:

1
2
3
4
5
>>> for in b:print k,b[k]
... 
liu Defensor
zeng Defensor
zhou Defensor


第二种方法:

1
2
3
4
5
>>> for k,v in dic.items():print k,v
... 
liu 23
zhou 22
zeng 21

这两种方法的区别:第二种方法在字典数据量太大,如上百万条时,需要将字典先转换成列表,再处理。所以处理很慢,且影响性能。


pop()

删除给定key的键值对,并返回结果

1
2
3
4
5
6
>>> dic
{'liu': 23, 'zhou': 22, 'zeng': 21}
>>> dic.pop('liu')
23
>>> dic
{'zhou': 22, 'zeng': 21}


popitem()

随机删除键值对 

1
2
3
4
5
6
>>> dic
{'liu': 30, 'zhou': 22, 'zeng': 21}
>>> dic.popitem()
('liu', 30)
>>> dic
{'zhou': 22, 'zeng': 21}


     

setdefault(key):

如果字典中有指定的key,则打印该key对应的value,如果没有这个key,则创建一个键值对,value为

None

1
2
3
4
5
6
7
>>> dic
{'zhou': 22, 'zeng': 21}
>>> dic.setdefault('liu')
>>> dic
{'liu': None, 'zhou': 22, 'zeng': 21}
>>> dic.setdefault('zeng')
21


setdefault(key,value):

如果字典中有指定的key,则返回该key对应的value,如果没有这个key,则创建一个键值对 ,并返回value

1
2
3
4
5
6
7
8
>>> dic
{'liu': None, 'zhou': 22, 'zeng': 21}
>>> dic.setdefault('yin',20)
20
>>> dic
{'liu': None, 'yin': 20, 'zhou': 22, 'zeng': 21}
>>> dic.setdefault('zhou',25)
22


 

dica.pdate(dictb) : 

循环dictb中的每一个key是否在dicta中存在,如不存在,则将dictb中的键值对加入到dicta中。如果key在dicta中存在,则将dicta中的key的值改成dictb中同一个key对应的值

1
2
3
4
5
>>> a={1:1,2:2}
>>> b={1:11,2:2,3:3}
>>> a.update(b)
>>> a
{1: 11, 2: 2, 3: 3}



copy() 和deepcopy()  深复制和浅复制

利用切片操作和工厂方法list方法拷贝就叫浅拷贝,只是拷贝了最外围的对象本身,内部的元素都只是拷贝了一个引用而已。 

利用copy中的deepcopy方法进行拷贝就叫做深拷贝,外围和内部元素都进行了拷贝对象本身,而不是引用。

1
2
3
4
5
6
7
8
9
10
11
>>> import copy
>>> jack = ['jack',['age','20']]
>>> tom = copy.deepcopy(jack)
>>> anny = copy.copy(jack)
>>> tom[0]='tom'
>>> anny[0]='anny'
>>> print jack,tom,anny
['jack', ['age''20']] ['tom', ['age''20']] ['anny', ['age''20']]
>>> anny[1][1] = 18
>>> print jack,tom,anny
['jack', ['age', 18]] ['tom', ['age''20']] ['anny', ['age', 18]]


浅拷贝图解 

wKioL1dmW97SWXM5AACRrD8T_rg303.png










本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1790817,如需转载请自行联系原作者
目录
相关文章
|
1天前
|
JSON 程序员 数据格式
优雅地处理Python中的条件分支:字典映射、函数组合与match-case语句
在本文中,我们探讨了如何在Python中优雅地处理条件分支,以避免使用过多的if语句。文章介绍了两种解决方案:字典映射与函数组合以及Python 3.10中引入的match-case语句。这些方法使得代码结构更加清晰、简洁且易于维护和扩展。
15 0
|
4天前
|
存储 Python
Python列表元组字典集合存储结构 2
Python列表元组字典集合存储结构
10 0
|
4天前
|
存储 程序员 Python
Python列表元组字典集合存储结构1
Python列表元组字典集合存储结构
7 0
|
4天前
|
存储 数据处理 Python
标题:Python数据结构详解:列表、元组、字典和集合
标题:Python数据结构详解:列表、元组、字典和集合
|
10天前
|
存储 数据库 Python
Python学习手册--第三部分(if语句和字典)
Python学习手册--第三部分(if语句和字典)
|
14天前
|
存储 Python
Python字典和集合操作指南:创建、获取值、修改和删除键值对,复制和遍历方法全解析
Python字典和集合操作指南:创建、获取值、修改和删除键值对,复制和遍历方法全解析
18 0
|
14天前
|
存储 索引 Python
【python基础知识】4.列表和字典
【python基础知识】4.列表和字典
27 0
|
18天前
|
索引 Python
python 中的列表,元组,字典,集合
python 中的列表,元组,字典,集合
24 1
|
19天前
|
Python
Python程序设计实例 | 字典
* 本系列推文案例中,建议Python采用3.10及以上版本,NumPy采用1.22.3及以上版本,Matplotlib采用3.5.1及以上版本,Pandas采用1.4.2及以上版本。Python从3.10这个版本开始,标准发行版本中自带的IDLE交互式环境中输入提示符>>>单独放在左侧,不能随输入语句一起复制。为了清晰区分实例在交互环境中的输入和输出,本系列推文在每个输入语句的开头依然保留输入提示符>>>。
52 0
|
20天前
|
存储 自然语言处理 索引
Python 遍历字典的若干方法
Python 遍历字典的若干方法
相关产品
云迁移中心
推荐文章
更多