美文网首页python基础
内置数据结构-字典

内置数据结构-字典

作者: loveroot | 来源:发表于2017-01-10 22:08 被阅读19次

字典是Key : Value结构的数据结构

  • key必须为可hash
  • key必须唯一
  • value可为任意对象
  • 不能切片,可迭代, 可修改
创建字典
初始化一个空字典
d = dict() or d = {}

创建有元素的字典
In [9]: d = dict({'a':2})

In [10]: d
Out[10]: {'a': 2}

In [13]: d2 = {'k1': 'hello', 'k2': 'python'}

In [11]: type(d)
Out[11]: dict

下标来操作字典
In [15]: d2['k1']
Out[15]: 'hello'

下标访问不存在的key时会报错
In [16]: d2['k3']
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-16-8f242878f70d> in <module>()
----> 1 d2['k3']

KeyError: 'k3'

增加元素,如果key存在,则会覆盖旧的value
通过下标增加
In [17]: d2['k3'] = '!'

In [18]: d2
Out[18]: {'k1': 'hello', 'k2': 'python', 'k3': '!'}

update()方法增加
In [19]: d
Out[19]: {'a': 2}

通过字典增加
In [20]: d.update({'b': 3, 'c': 4})

In [21]: d
Out[21]: {'a': 2, 'b': 3, 'c': 4}

通过二元组组成的可迭代对象
In [23]: d.update([('e', 10), ('f', 11)])

In [24]: d
Out[24]: {'a': 2, 'b': 3, 'c': 4, 'e': 10, 'f': 11}

通过关键字参数
In [25]: d.update(g=100)

In [26]: d
Out[26]: {'a': 2, 'b': 3, 'c': 4, 'e': 10, 'f': 11, 'g': 100}

通过 setdefault()增加,如果再次setdefault已经存在的key则不会修改value
In [41]: d.setdefault('a', 'a')
Out[41]: 'a'

In [42]: d
Out[42]: {'a': 'a', 'b': 3, 'e': 10, 'f': 11, 'g': 100}

In [43]: d['a'] = 123

In [44]: d
Out[44]: {'a': 123, 'b': 3, 'e': 10, 'f': 11, 'g': 100}

In [51]: d.setdefault('a',234)
Out[51]: 123

In [52]: d
Out[52]: {'a': 123, 'b': 3, 'e': 10, 'f': 11, 'g': 100}



删除元素

In [27]: d
Out[27]: {'a': 2, 'b': 3, 'c': 4, 'e': 10, 'f': 11, 'g': 100}

In [28]: d.pop('a')
Out[28]: 2

删除不存在的key时,给定了默认值不会报keyerror,并返回此值 
In [29]: d.pop('aa','not exist')
Out[29]: 'not exist'

In [30]: d.pop('aa')
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-30-8506ee8a21ae> in <module>()
----> 1 d.pop('aa')

KeyError: 'aa'


popitem()随机弹出一个key-value元组,如果字典为空则KeyError
In [31]: d
Out[31]: {'b': 3, 'c': 4, 'e': 10, 'f': 11, 'g': 100}

In [32]: d.popitem()
Out[32]: ('c', 4)

In [33]: d3 = {}

In [34]: d3.popitem()
---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
<ipython-input-34-aad629fbb3ef> in <module>()
----> 1 d3.popitem()

KeyError: 'popitem(): dictionary is empty'


clear() 清空字典

通过get()访问元素,与下标不同的是get的key不存在的时候返回None,给定了默认值返回此值
In [36]: d
Out[36]: {'b': 3, 'e': 10, 'f': 11, 'g': 100}

In [37]: d.get('b')
Out[37]: 3

In [38]: d.get('bb')

In [39]: d.get('bb', 'bb not exist')
Out[39]: 'bb not exist'


扩展
In [45]: from collections import defaultdict

defaultdict和普通dict类似,只是初始化的时候需要给定一个默认的可调用对象
In [46]: dd = defaultdict(list)

In [47]: dd
Out[47]: defaultdict(list, {})

get无返回值 
In [48]: dd.get('a')

通过下标访问不存在的元素时会返回传入的可调用对象的实例
In [49]: dd['a']
Out[49]: []


字典的遍历

In [1]: d = {'k1': 'hello', 'k2': 'python'}

keys()方法返回一个 类set对象,可以和集合做运算
In [2]: d.keys()
Out[2]: dict_keys(['k1', 'k2'])

In [3]: for k in d.keys():
   ...:     print('{}=>{}'.format(k, d[k]))
   ...:     
k1=>hello
k2=>python 

In [4]: d.keys() | {1,2}
Out[4]: {'k1', 1, 2, 'k2'}


d.values()返回一个dict.values对象,因为value是可以重复的,所以不是类set对象, 不能和集合做运算
In [5]: d.values()
Out[5]: dict_values(['hello', 'python'])

In [6]: help(d.values)
Help on built-in function values:

values(...) method of builtins.dict instance
    D.values() -> an object providing a view on D's values


In [7]: d.values() | {1,2}
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-7-d9a6c76f0b9f> in <module>()
----> 1 d.values() | {1,2}

TypeError: unsupported operand type(s) for |: 'dict_values' and 'set'

 
遍历key和value
d.items()方法返回一个 类set对象,每个元素是一个Key-value二元组
In [8]: d.items()
Out[8]: dict_items([('k1', 'hello'), ('k2', 'python')])

In [9]: for k, v in d.items():
   ...:     print(k, v)
   ...:     
k1 hello
k2 python


fromkeys() 方法接收一个可迭代对象,和一个初始值 ,返回一个字典

In [10]: dict.fromkeys(['a', 'b', 'c'], None)
Out[10]: {'a': None, 'b': None, 'c': None}

In [11]: dict.fromkeys(['a', 'b', 'c'], True)
Out[11]: {'a': True, 'b': True, 'c': True}

In [12]: dict.fromkeys(['a', 'b', 'c'], 'python')
Out[12]: {'a': 'python', 'b': 'python', 'c': 'python'}

相关文章

  • redis里面字典的实现

    字典,又称符号表,是保存键值对的抽象数据结构。很多语言都内置字典这种常用的数据结构,但是C语言没有内置,所以red...

  • python基础5-字典

    什么是字典字典(Dictionary)是Python中的内置数据结构字典非常适合表达结构化数据 字典的特点采用键(...

  • 6字典[python基础]

    什么是字典字典(Dictionary)是Python中的内置数据结构字典非常适合表达结构化数据 字典的特点采用键(...

  • Python四个内置数据结构

    认识4个内置数据结构 Python提供了4个内置数据结构,可以用来保存任何对象集合,它们分别是列表、元组、字典、集...

  • redis-字典

    redis所使用的C语言并没有内置丰富的数据结构,因而redis实现了很多数据结构,本文主要介绍字典。 字典又叫映...

  • Python 数据结构

    Python 有四种内置的数据结构 - 列表(List),元组(Tuple),字典(Dictionary),集合(...

  • 内置数据结构-字典

    字典是Key : Value结构的数据结构 key必须为可hash key必须唯一 value可为任意对象 不能切...

  • 字典

    字典的操作方法 字典是python中唯一的映射类型,字典也是python中出列表外,最灵活的内置数据结构类型.列表...

  • python 数据结构

    python包含数据结构包含list列表、tuple元组、dict字典、set集合这些都是内置类型。collect...

  • Python编程中3个常用的数据结构和算法

    Python内置了许多非常有用的数据结构,比如列表(list)、集合(set)以及字典(dictionary)。就...

网友评论

    本文标题:内置数据结构-字典

    本文链接:https://www.haomeiwen.com/subject/cwuwvttx.html