一. 字典
字典是另一种可变容器模型,且可存储任意类型对象。
字典的每个键值 key=>value 对用冒号 :
分割,每个对之间用逗号( , )分割,整个字典包括在花括号 {}
中 。
dict 作为 Python 的关键字和内置函数,变量名不建议命名为 dict。
键必须是唯一的,但值则不必。
值可以取任何数据类型,但键必须是不可变的,如字符串,数字。
tinydict = {'name': '潘家辉大佬', 'grade': 666, 'url': '能不能不要再卷我了!!!'}
print(tinydict)
1> 空字典
a. 使用大括号创建字典。
emptyDict = {}
# 打印字典
print(emptyDict)
# 查看字典的数量
print("Length:", len(emptyDict))
# 查看类型
print(type(emptyDict))
b. 使用内建函数 dict() 创建字典。
emptyDict = dict()
# 打印字典
print(emptyDict)
# 查看字典的数量
print("Length:",len(emptyDict))
# 查看类型
print(type(emptyDict))
2> 读取字典里的值
把相应的键放入到方括号中。
tinydict = {'Name': '潘家辉', 'Age': 555, 'Class': 'NumberOne'}
print("tinydict['Name']: ", tinydict['Name'])
print("tinydict['Age']: ", tinydict['Age'])
如果用字典里没有的键访问数据,会输出错误。
3> 修改字典里的值
tinydict = {'Name': '潘家辉', 'Age': 666, 'Class': 'NumberOne'}
tinydict['Age'] = 999 # 更新 Age
tinydict['School'] = "m大学" # 添加信息
print("tinydict['Age']: ", tinydict['Age'])
print("tinydict['School']: ", tinydict['School'])
可以出Age从666变成888,多添加了个键与值。
4> 删除字典元素
能删单一的元素也能清空字典.clear()
,清空只需一项操作,显式删除一个键或字典用del命令典。
tinydict = {'Name': '潘家辉', 'Age': 666, 'Class': 'NumberOne'}
del tinydict['Name'] # 删除键 'Name'
print("tinydict['Age']: ", tinydict['Age'])
tinydict.clear() # 清空字典
print("tinydict['Age']: ", tinydict['Age'])
del tinydict # 删除字典
print("tinydict['Age']: ", tinydict['Age'])
5> 字典键的特性
字典值可以是任何的 python 对象,既可以是标准的对象,也可以是用户定义的,但键不行。
两个重要的点需要记住:
- 不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住。
- 键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行。
6> 字典内置函数与方法
a. Python字典包含了以下内置函数:
序号 | 函数及描述 |
---|---|
1 | len(dict) 计算字典元素个数,即键的总数。 |
2 | str(dict) 输出字典,可以打印的字符串表示。 |
3 | type(variable) 返回输入的变量类型,如果变量是字典就返回字典类型。 |
b. Python字典包含了以下内置方法:
序号 | 函数及描述 |
---|---|
1 | [dict.clear()] 删除字典内所有元素 |
2 | [dict.copy()] 返回一个字典的浅复制 |
3 | [dict.fromkeys()]创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值 |
4 | [dict.get(key, default=None)] 返回指定键的值,如果键不在字典中返回 default 设置的默认值 |
5 | [key in dict] 如果键在字典dict里返回true,否则返回false |
6 | [dict.items()] 以列表返回一个视图对象 |
7 | [dict.keys()]返回一个视图对象 |
8 | [dict.setdefault(key, default=None)] 和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default |
9 | [dict.update(dict2)]把字典dict2的键/值对更新到dict里 |
10 | [dict.values()] 返回一个视图对象 |
11 | [pop(key[,default])]l) 删除字典 key(键)所对应的值,返回被删除的值。 |
12 | [popitem()] 返回并删除字典中的最后一对键和值。 |
二. 集合(Set)
集合(set)是一个无序的不重复元素序列。
可以使用大括号 { }
或者 set()
函数创建集合
注意:创建一个空集合必须用 set()
而不是 { }
,因为 { }
是用来创建一个空字典。
# 可以理解为这个是一个没有键,只有值的字典,也叫做集合。
fruit = {'潘家辉', '大佬', '你', '真', '棒!'}
print(fruit)
# set()集合函数
a = set('abcccd')
print(a)
b = set('ad')
c = a-b
print(c)
可以看出输出结果不是固定的,是个无序的不重复元素序列。
- a-b(集合a中包含而集合b中不包含的元素)
- a|b(集合a或b中包含的所有元素)
- a&b(集合a和b中都包含了的元素)
- a^b(不同时包含于a和b的元素)
1> 添加元素
- add()函数,将元素添加到集合中,如果元素已存在,则不进行任何操作。
- update()函数,添加元素,且参数可以是列表,元组,字典等。
student = set(("潘", "鸽", "真"))
student.add("强")
print(student)
student.update({1,2,3})
print(student)
2> 删除元素
- remove()函数,将元素从集合中移除,如果元素不存在,则会发生错误。
- discard()函数,将元素从集合中移除,且如果元素不存在,不会发生错误。
- pop()函数,将集合进行无序的排列,然后将这个无序排列集合的左面第一个元素进行删除。
student = set(("潘", "鸽", "真"))
student.remove("强")
print(student)
student.discard("嘻嘻")
print(student)
student.pop()
print(student)
student = set(("潘", "鸽", "真"))
student.remove("鸽")
print(student)
student.discard("嘻嘻")
print(student)
student.pop()
print(student)
3> 计算集合元素个数
student = set(("潘", "鸽", "真", "强"))
print(len(student))
4> 清空集合
student = set(("潘", "鸽", "真", "强"))
print(student)
student.clear()
print(student)
5> 判断元素是否在集合中存在
student = set(("潘", "鸽", "真", "强"))
print("潘" in student)
print("h" in student)
6> 集合内置方法完整列表
方法 | 描述 |
---|---|
[add()] | 为集合添加元素 |
[clear()] | 移除集合中的所有元素 |
[copy()] | 拷贝一个集合 |
[difference()] | 返回多个集合的差集 |
[difference_update()] | 移除集合中的元素,该元素在指定的集合也存在。 |
[discard()] | 删除集合中指定的元素 |
[intersection()] | 返回集合的交集 |
[intersection_update()] | 返回集合的交集。 |
[isdisjoint()] | 判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。 |
[issubset()] | 判断指定集合是否为该方法参数集合的子集。 |
[issuperset()] | 判断该方法的参数集合是否为指定集合的子集 |
[pop()] | 随机移除元素 |
[remove()] | 移除指定元素 |
[symmetric_difference()] | 返回两个集合中不重复的元素集合。 |
[symmetric_difference_update()]symmetric_difference_update.html) | 移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。 |
[union()] | 返回两个集合的并集 |
[update()] | 给集合添加元素 |