字典由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
k
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]]
|
浅拷贝图解