上一篇文章出现了个明显的知识点错误,不过感谢有个网友的提出,及时进行了修改。也但愿各位多多包涵。python
通过以前的学习,咱们能够知道 list 和 tuple 能够用来表示有序集合,以前咱们那个例子是用 list 来存储了用户的昵称数组
user=['liangdianshui','twowater','两点水']复制代码
若是咱们须要把用户的帐号也记录进去呢?函数
用 list 能够这样子解决:性能
user=[['liangdianshui','111111'],['twowater','222222'],['两点水','333333']]复制代码
但是这样表示也不方便,并且很难根据昵称找到对应的昵称,且 list 越长,耗时越长;这时候就能够用 dict (字典)来表示了,Python 内置了 字典(dict),dict 全称dictionary,至关于 JAVA 中的 map,使用键-值(key-value)存储,具备极快的查找速度。学习
user={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333'}复制代码
字典是另外一种可变容器模型,且可存储任意类型对象。测试
字典的每一个键值(key=>value)对用冒号(:)分割,每一个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式以下所示:ui
dict = {key1 : value1, key2 : value2 }复制代码
注意:键必须是惟一的,但值则没必要。值能够取任何数据类型,但键必须是不可变的。spa
建立 dict(字典)实例:code
dict1={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333'}
dict2={'abc':1234,1234:'abc'}复制代码
#-*-coding:utf-8-*-
dict1={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333'}
print(dict1)复制代码
输出的结果:cdn
{'liangdianshui': '111111', 'twowater': '222222', '两点水': '333333'}复制代码
这里须要注意的一点是:若是字典中没有这个键,是会报错的。
向字典添加新内容的方法是增长新的键/值对,修改或删除已有键/值对
#-*-coding:utf-8-*-
dict1={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333'}
print(dict1)
# 新增一个键值对
dict1['jack']='444444'
print(dict1)
# 修改键值对
dict1['liangdianshui']='555555'
print(dict1)复制代码
输出的结果:
{'liangdianshui': '111111', 'twowater': '222222', '两点水': '333333'}
{'liangdianshui': '111111', 'twowater': '222222', '两点水': '333333', 'jack': '444444'}
{'liangdianshui': '555555', 'twowater': '222222', '两点水': '333333', 'jack': '444444'}复制代码
经过 del
能够删除 dict (字典)中的某个元素,也能删除 dict (字典)
经过调用 clear()
方法能够清除字典中的全部元素
#-*-coding:utf-8-*-
dict1={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333'}
print(dict1)
# 经过 key 值,删除对应的元素
del dict1['twowater']
print(dict1)
# 删除字典中的全部元素
dict1.clear()
print(dict1)
# 删除字典
del dict1复制代码
输出的结果:
{'liangdianshui': '111111', 'twowater': '222222', '两点水': '333333'}
{'liangdianshui': '111111', '两点水': '333333'}
{}复制代码
(1) dict (字典)是不容许一个键建立两次的,可是在建立 dict (字典)的时候若是出现了一个键值赋予了两次,会以最后一次赋予的值为准
例如:
#-*-coding:utf-8-*-
dict1={'liangdianshui':'111111' ,'twowater':'222222' ,'两点水':'333333','twowater':'444444'}
print(dict1)
print(dict1['twowater'])复制代码
输出的结果:
{'liangdianshui': '111111', 'twowater': '444444', '两点水': '333333'}
444444复制代码
(2) dict (字典)键必须不可变,但是键能够用数字,字符串或元组充当,可是就是不能使用列表
例如:
#-*-coding:utf-8-*-
dict1={'liangdianshui':'111111' ,123:'222222' ,(123,'tom'):'333333','twowater':'444444'}
print(dict1)复制代码
输出结果:
{'liangdianshui': '111111', 123: '222222', (123, 'tom'): '333333', 'twowater': '444444'}复制代码
(3) dict 内部存放的顺序和 key 放入的顺序是没有任何关系
和 list 比较,dict 有如下几个特色:
查找和插入的速度极快,不会随着key的增长而变慢
须要占用大量的内存,内存浪费多
而list相反:
查找和插入的时间随着元素的增长而增长
占用空间小,浪费内存不多
方法和函数 | 描述 |
---|---|
cmp(dict1, dict2) | 比较两个字典元素 |
len(dict) | 计算字典元素个数 |
str(dict) | 输出字典可打印的字符串表示 |
type(variable) | 返回输入的变量类型,若是变量是字典就返回字典类型 |
dict.clear() | 删除字典内全部元素 |
dict.copy() | 返回一个字典的浅复制 |
dict.values() | 以列表返回字典中的全部值 |
popitem() | 随机返回并删除字典中的一对键和值 |
dict.items() | 以列表返回可遍历的(键, 值) 元组数组 |
python 的 set 和其余语言相似, 是一个无序不重复元素集, 基本功能包括关系测试和消除重复元素。set 和 dict 相似,可是 set 不存储 value 值的。
建立一个 set,须要提供一个 list 做为输入集合
set1=set([123,456,789])
print(set1)复制代码
输出结果:
{456, 123, 789}复制代码
传入的参数 [123,456,789]
是一个 list,而显示的 {456, 123, 789}
只是告诉你这个 set 内部有 456, 123, 789 这 3 个元素,显示的顺序跟你参数中的 list 里的元素的顺序是不一致的,这也说明了 set 是无序的。
还有一点,咱们观察到输出的结果是在大括号中的,通过以前的学习,能够知道,tuple (元组) 使用小括号,list (列表) 使用方括号, dict (字典) 使用的是大括号,dict 也是无序的,只不过 dict 保存的是 key-value 键值对值,而 set 能够理解为只保存 key 值。
回忆一下,在 dict (字典) 中建立时,有重复的 key ,会被后面的 key-value 值覆盖的,而 重复元素在 set 中自动被过滤的。
set1=set([123,456,789,123,123])
print(set1)复制代码
输出的结果:
{456, 123, 789}复制代码
经过 add(key) 方法能够添加元素到 set 中,能够重复添加,但不会有效果
set1=set([123,456,789])
print(set1)
set1.add(100)
print(set1)
set1.add(100)
print(set1)复制代码
输出结果:
{456, 123, 789}
{456, 123, 100, 789}
{456, 123, 100, 789}复制代码
经过 remove(key) 方法能够删除 set 中的元素
set1=set([123,456,789])
print(set1)
set1.remove(456)
print(set1)复制代码
输出的结果:
{456, 123, 789}
{123, 789}复制代码
由于 set 是一个无序不重复元素集,所以,两个 set 能够作数学意义上的 union(并集), intersection(交集), difference(差集) 等操做。
例子:
set1=set('hello')
set2=set(['p','y','y','h','o','n'])
print(set1)
print(set2)
# 交集 (求两个 set 集合中相同的元素)
set3=set1 & set2
print('\n交集 set3:')
print(set3)
# 并集 (合并两个 set 集合的元素并去除重复的值)
set4=set1 | set2
print('\n并集 set4:')
print(set4)
# 差集
set5=set1 - set2
set6=set2 - set1
print('\n差集 set5:')
print(set5)
print('\n差集 set6:')
print( set6)
# 去除海量列表里重复元素,用 hash 来解决也行,只不过感受在性能上不是很高,用 set 解决仍是很不错的
list1 = [111,222,333,444,111,222,333,444,555,666]
set7=set(list1)
print('\n去除列表里重复元素 set7:')
print(set7)复制代码
运行的结果:
{'h', 'l', 'e', 'o'}
{'h', 'n', 'o', 'y', 'p'}
交集 set3:
{'h', 'o'}
并集 set4:
{'h', 'p', 'n', 'e', 'o', 'y', 'l'}
差集 set5:
{'l', 'e'}
差集 set6:
{'p', 'y', 'n'}
去除列表里重复元素 set7:
{555, 333, 111, 666, 444, 222}复制代码