版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本系列定位为复习笔记,某些内容并未提及。
在此记录一些典型疑问和我在学习中的问题或经常遗忘的细节,也会添加一些觉得有意思的部分(其实就是随心所欲 )
内容主要使用代码进行传达
字典(哈希表)的创建与索引访问
字典以"关键字"为索引,关键字可以是任意不可变类型,通常用字符串或数值。
字典是 Python 唯一的一个 映射类型,字符串、元组、列表属于序列类型。
字典的关键字不可变,这是由哈希的特质决定的,只有不可修改的变量才能进行哈希 如
>>> hash(2)
2
>>> hash('asdsdqawfa')
4159286438170111909
>>> hash((1,2,3))
2528502973977326415
>>> hash([1,2,3])
Traceback (most recent call last):
File "<pyshell#1>", line 1, in <module>
hash([1,2,3])
TypeError: unhashable type: 'list'
创建
dict1 = {'李宁': '一切皆有可能', '耐克': 'Just do it', '阿迪达斯': 'Impossible is nothing'}
print('耐克的口号是:', dict1['耐克'])
# 耐克的口号是: Just do it
dict函数创建
dict() -> new empty dictionary
dict(mapping) -> new dictionary initialized from a mapping object’s (key, value) pairs
dict(iterable) -> new dictionary initialized as if via:
特别的:
dict4 = dict([('apple', 4139), ('peach', 4127), ('cherry', 4098)])
print(dict4) # {'cherry': 4098, 'apple': 4139, 'peach': 4127}
dict4 = dict((('apple', 4139), ('peach', 4127), ('cherry', 4098)))
print(dict4) # {'peach': 4127, 'cherry': 4098, 'apple': 4139}
字典内置方法:
- dict.fromkeys(seq[, value]) 用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。
- dict.keys()返回一个可迭代对象,可以使用 list() 来转换为列表。
- dict.values()返回一个迭代器,可以使用 list() 来转换为列表,列表为字典中的所有值。
- dict.items()以列表返回可遍历的(键, 值) 元组数组。
- dict.get(key, default=None)返回指定键的值,如果值不在字典中返回默认值。
- key in dict in 操作符用于判断键是否存在于字典中,如果键在字典 dict 里返回true,否则返回false。而not in操作符刚好相反,如果键在字典 dict 里返回false,否则返回true。
- dict.clear()用于删除字典内所有元素。
- dict.copy()返回一个字典的浅复制。
注意直接赋值与copy浅复制的区别:
dict1 = {'user': 'lsgogroup', 'num': [1, 2, 3]}
dict2 = dict1
dict3 = dict1.copy()
print(id(dict1)) # 148635574728
print(id(dict2)) # 148635574728
print(id(dict3)) # 148635574344
- dict.pop(key[,default])删除字典给定键 key 所对应的值,返回值为被删除的值。key 值必须给出。 否则,返回default 值。
- del dict[key] 删除字典给定键 key 所对应的值。
- dict.popitem()随机返回并删除字典中的一对键和值,如果字典已经为空,却调用了此方法,就报出KeyError异常。
- dict.setdefault(key, default=None)和get()方法 类似, 如果键不存在于字典中,将会添加键并将值设为默认值。
- dict.update(dict2)把字典参数 dict2 的 key/value(键/值) 对更新到字典 dict 里。
集合:
集合元素具有互异性与唯一性,可以用来去掉列表中重复的元素等操作
创建:
直接把一堆元素用花括号括起来{元素1, 元素2, …, 元素n},重复元素在set中会被自动被过滤。
basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
print(basket) # {'banana', 'apple', 'pear', 'orange'}
- 使用set(value)工厂函数,把列表或元组转换成集合。
- 可以使用for把集合中的数据一个个读取出来。
- 可以通过in或not in判断一个元素是否在集合中已经存在