目录
第八天学习Python,今天学习掌握字典与集合。
字典
字典是另一种可变容器模型,且可存储任意类型对象。
格式
字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中
- 格式如下所示
d = {key1 : value1, key2 : value2 }
注意 键必须是唯一的,但值则不必。
值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组。
- 字典实例
dict0 = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'}
dict1 = { 'abc': 456 }
dict2 = { 'abc': 123, 98.6: 37 }
访问字典里的值
- 实例
dict = {'Name': 'Hello', 'Age': 7, 'Class': 'First'}
print ("dict['Name']: ", dict['Name'])
print ("dict['Age']: ", dict['Age'])
以上实例输出结果
dict['Name']: Hello
dict['Age']: 7
修改字典
向字典添加新内容的方法是增加新的键/值对,修改或删除已有键/值对
- 实例
dict = {'Name':'Hello', 'Age': 7, 'Class': 'First'}
dict['Age'] = 8 # 更新 Age
dict['School'] = "Python" # 添加信息
print ("dict['Age']: ", dict['Age'])
print ("dict['School']: ", dict['School'])
以上实例输出结果:
dict['Age']: 8
dict['School']: Python
字典内置函数&方法
- Python字典包含了以下内置函数
dict = {‘Name’: ‘Hello’, ‘Age’: 7, ‘Class’: ‘First’}
函数 | 描述 | 实例 |
---|---|---|
len(dict) | 计算字典元素个数,即键的总数。 | len(dict) 结果为3 |
str(dict) | 输出字典,以可打印的字符串表示。 | str(dict) 结果为"{'Name': 'Runoob', 'Class': 'First', 'Age': 7}" |
type(variable) | 返回输入的变量类型,如果变量是字典就返回字典类型。 | type(dict) 结果为<class 'dict'> |
- Python字典包含了以下内置方法
函数 | 描述 |
---|---|
radiansdict.clear() | 删除字典内所有元素 |
radiansdict.copy() | 返回一个字典的浅复制 |
radiansdict.fromkeys() | 创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值 |
radiansdict.get(key, default=None) | 返回指定键的值,如果值不在字典中返回default值 |
key in dict | 如果键在字典dict里返回true,否则返回false |
radiansdict.items() | 以列表返回可遍历的(键, 值) 元组数组 |
radiansdict.keys() | 返回一个迭代器,可以使用 list() 来转换为列表 |
radiansdict.setdefault(key, default=None) | 和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default |
radiansdict.update(dict2) | 把字典dict2的键/值对更新到dict里 |
radiansdict.values() | 返回一个迭代器,可以使用 list() 来转换为列表 |
pop(key[,default]) | 删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。否则,返回default值 |
popitem() | 随机返回并删除字典中的最后一对键和值 |
集合
集合(set)是一个无序的不重复元素序列。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式
parame = {value01,value02,…}或者set(value)
注意 类似列表推导式,同样集合支持集合推导式(Set comprehension)
- 实例
>>>a = {x for x in 'abracadabra' if x not in 'abc'}
>>> a
{'r', 'd'}
集合的基本操作
1.添加元素
语法格式如下
s.add( x )
还有一个方法,也可以添加元素,且参数可以是列表,元组,字典等,语法格式如下
s.update( x )
将元素 x 添加到集合 s 中,如果元素已存在,则不进行任何操作。
- 实例
thisset = set(("Google", "Taobao"))
thisset.add("Facebook")
print(thisset)
thisset.update({1,3})
print(thisset)
结果为
{'Taobao', 'Facebook', 'Google'}
{1, 3, 'Taobao', 'Facebook', 'Google'}
2.移除元素
语法格式如下
s.remove( x )
此外还有一个方法也是移除集合中的元素,且如果元素不存在,不会发生错误。格式如下所示
s.discard( x )
我们也可以设置随机删除集合中的一个元素,语法格式如下
s.pop()
>>>thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
>>> thisset.pop()
'Facebook'
>>> print(thisset)
{'Google', 'Taobao', 'Runoob'}
将元素 x 从集合 s 中移除,如果元素不存在,则会发生错误。
- 实例
thisset = set(("Google", "Taobao","Baidu"))
thisset.remove("Taobao")
print(thisset)
结果为
{'Google',"Baidu"}
3.计算集合元素个数
语法格式如下
len(s)
- 实例
>>>thisset = set(("Google", "Taobao"))
>>> len(thisset)
2
4.清空集合
语法格式如下
s.clear()
- 实例
>>>thisset = set(("Google", "Taobao"))
>>> thisset.clear()
>>> print(thisset)
set()
5.判断元素是否在集合中存在
语法格式如下
x in s
判断元素 x 是否在集合 s 中,存在返回 True,不存在返回 False。
- 实例
>>>thisset = set(("Google", "Taobao"))
>>> "Taobao" in thisset
True
>>> "Baidu" in thisset
False
集合内置方法
方法 | 描述 |
---|---|
add() | 为集合添加元素 |
clear() | 移除集合中的所有元素 |
copy() | 拷贝一个集合 |
difference() | 返回多个集合的差集 |
difference_update() | 移除集合中的元素,该元素在指定的集合也存在 |
discard() | 删除集合中指定的元素 |
intersection() | 返回集合的交集 |
intersection_update() | 返回集合的交集 |
isdisjoint() | 判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False |
issubset() | 判断指定集合是否为该方法参数集合的子集 |
issuperset() | 判断该方法的参数集合是否为指定集合的子集 |
pop() | 随机移除元素 |
remove() | 移除指定元素 |
symmetric_difference() | 返回两个集合中不重复的元素集合 |
symmetric_difference_update() | 移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中 |
union() | 返回两个集合的并集 |
update() | 给集合添加元素 |