Python学习笔记6-字典与集合

本文最后更新于 将近 6 年前,文中所描述的信息可能已发生改变。

字典与集合

字典 (dict)

键-值(key-value)存储

你可以想象是数学中的函数f(x) 一个x对应一个f(x) 例如:

python
>>> a = {"it1" : "hello"}
>>> a["it1"]
"hello"
  • 相较与json,内部的dict里可以用",而json不能使用" 例如: {"year":"2019"} 使用JSON.parse()后就会报错,必须将"替换成'才能解析json
  • 一个key只能对应一个value,如果key不存在,dict就会报错
python
>>> a['a']
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
KeyError: 'a'
  • 要避免key不存在的错误,有两种办法:
  1. 一是通过in判断key是否存在
python
>>> "a" in a
False
  1. 通过dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value
python
>>> a.get('a')
>>> a.get('a',-1)
-1

和list比较,dict有以下几个特点: 查找和插入的速度极快,不会随着key的增加而变慢; 需要占用大量的内存,内存浪费多。 而list相反: 查找和插入的时间随着元素的增加而增加; 占用空间小,浪费内存很少。 所以,dict是用空间来换取时间的一种方法。 – dict的key必须是不可变对象。 – dict操作函数 3. del

python
>>> dict = {'Name': 'Ami', 'Age': 7}
>>> dict
{'Name': 'Ami', 'Age': 7}
>>> del dict['Age']
>>> dict
{'Name': 'Ami'}
  1. pop(key)方法,对应的value也会从dict中删除
python
>>> dict = {'Name': 'Ami', 'Age': 7}
>>> dict.pop('Age')
7
>>> dict
{'Name': 'Ami'}
  • Python字典包含了以下内置函数:
序号函数描述
1cmp(dict1, dict2)比较两个字典元素。
2len(dict)计算字典元素个数,即键的总数。
3str(dict)输出字典可打印的字符串表示。
4type(variable)返回输入的变量类型,如果变量是字典就返回字典类型。
  • Python字典包含了以下内置方法:
序号函数描述
1dict.clear()删除字典内所有元素
2dict.copy()返回一个字典的浅复制
3dict.fromkeys(seq[, val])创建一个新字典,以序列 seq 中元素做字典的键,val 为字典所有键对应的初始值
4dict.get(key, default=None)返回指定键的值,如果值不在字典中返回default值
5dict.has_key(key)如果键在字典dict里返回true,否则返回false
6dict.items()以列表返回可遍历的(键, 值) 元组数组
7dict.keys()以列表返回一个字典所有的键
8dict.setdefault(key, default=None)和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
9dict.update(dict2)把字典dict2的键/值对更新到dict里
10dict.values()以列表返回字典中的所有值
11pop(key[,default])删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。
12popitem()返回并删除字典中的最后一对键和值。

set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

  • 要创建一个set,需要提供一个list作为输入集合:
python
>>> s=set([1,1,1])
>>> s
{1}
>>>
  • 通过add(key)方法可以添加元素到set中
python
>>> s.add(2)
>>> s
{1, 2}
  • 通过remove(key)方法可以删除元素:
python
>>> s.remove(2)
>>> s
{1}
Python学习笔记5-函数与Lambda表达式
Python学习笔记7-文件与文件系统