字典dict
字典是由大括号{键:值}组成、字典是无序的、字典的键必须是不可变数据类型、不能使用列表作为键,但可以使用元祖作为字典的键。例如:
dict_ = {"test":"Hello World"}
str_ = "hello"
dict_ = {str_:"霍元甲"} # 这是正确的
list_ = [1,2,3]
dict_ = {list_:"西游记"} # 这是错误的
tuple_ = (1,2,3)
dic = {tuple_:"红楼梦"} # 这是正确的
dict_ = {1:"陈真"} # 这是正确的
dict_ = {True:"霍东阁"} # 这是正确的
dict_1 = {"字典":"值"}
dict_ = {dict_1:"三国演义"} # 这是错误的
新增
setdefault(键,值):如果只写键不写值将打印该键所对应的值,如果没有找到键返回Note。
dict_ = {"电视剧":"笑傲江湖"}
dict_["电影"] = "黄飞鸿"
dict_.setdefault("新增","我是新增的") # setdefault()函数添加键值对
print(dict_)
# 打印如下内容:
{'电视剧': '笑傲江湖', '电影': '黄飞鸿', '新增': '我是新增的'}
# 如果setdefault(键)如果只写键不写值是查询键的值.
print(dict_.setdefault("新增"))
# 打印如下内容:
我是新增的
fromkeys(字典键列表,值):如果值是列表,是可变的,那么如果更改列表中的值会影响整个字典键中的值。
dict_ = {}
list_str = ["name","age"]
dict_ = dict_.fromkeys(list_str,[1,2,3])
dict_["name"].append(4) # 向dict_["name"]中追加元素4
print(dic)
# 打印内容如下:
{'name': [1, 2, 3, 4], 'age': [1, 2, 3, 4]} # 发现修改name键的值后,age键的值也发生了改变,和name键的值一样
可以通过重新给键赋值的方法,摆脱更改键中的值,而影响整个字典中键的值。
dic={}
s = ["name","age"]
dic = dic.fromkeys(s,[1,2,3])
dic["name"] = [10,2] # 给键"name"重新赋值
print(dic)
# 打印内容如下:
{'name': [10, 2], 'age': [1, 2, 3]}
删除
pop(键):删除字典中的键值对。
dict_ = {"电视剧":"西游记","电影":"少林寺"}
print(dict_.pop("test")) # pop()如果找不到键会报错
# 打印内容如下:
KeyError: 'test' # 没有找到键
给pop(键,提示信息):添加个参数,用于在没有找到键时提示给用户。
dict_ = {"电视剧":"西游记","电影":"少林寺"}
print(dict_.pop("test","没有找到该键")) # 可以在pop(键,提示信息)
# 打印内容如下:
没有找到该键 # 用于提示用户这个键没有找到.
pop(键,提示语句)是有返回值的,可以返回被删除的键的值。
dict_ = {"电视剧":"西游记","电影":"少林寺"}
ret = dict_.pop("电视剧")
print(dict_)
print("被删除的值是:",ret)
# 打印内容如下
{'电影': '少林寺'}
被删除的值是: 西游记
popitem():没有参数,返回值是被删除的键值对,Python3.6以上版本删除最后一项键值对,其它版本是随机删除一组键值对。
dict_ = {"电视剧":"西游记","电影":"少林寺"}
ret = dict_.popitem()
print(dict_)
print("被删除的键值对是:",ret)
# 打印内容如下
{'电视剧': '西游记'}
被删除的键值对是: ('电影', '少林寺')
查找
keys():打印字典所有的键。
dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.keys())
# 打印内容如下:
dict_keys(['电视剧', '电影'])
values():打印字典所有的值。
dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.values())
# 打印内容如下:
dict_values(['霍元甲', '黄飞鸿'])
items():打印字典所有的键值对。
dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.items())
# 打印内容下:
dict_items([('电视剧', '霍元甲'), ('电影', '黄飞鸿')])
由keys()、values()、items()的打印结果看,可能不是我们想要的。如果我们想要字符串需要进行如下转换:
dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
list_key = list(dict_.keys()) # 将键先转换成列表
str_ = " ".join(list_key) # 将列表转换成字符串
print("list_key:",list_key,"str_key:",str_)
list_value = list(dict_.values()) # 将值先转换成列表
str_ = " ".join(list_value) # 将列表转换成字符串
print("list_value:",list_value,"str_value:",str_)
list_item = list(dict_.items())
print("list_item:",list_item)
# 打印内容如下
list_key: ['电视剧', '电影'] str_key: 电视剧 电影
list_value: ['霍元甲', '黄飞鸿'] str_value: 霍元甲 黄飞鸿
list_item: [('电视剧', '霍元甲'), ('电影', '黄飞鸿')]
解构(常用操作)
a,b,c = 1,2,3
str_1,str_2 = "a","b"
list_1,list_2 = [1,2,3],["a","b","c"]
dict_1,dict_2 = {"电视剧":"上海滩"},{"电影":"黄飞鸿"}
print("a,b,c:",a,b,c,type(a),type(b),type(c))
print("str1,str2:",str_1,str_2,type(str_1),type(str_2))
print("list_1,list_2:",list_1,list_2,type(list_1),type(list_2))
print("dict_1,dict_2:",dict_1,dict_2,type(dict_1),type(dict_2))
# 打印内容如下:
a,b,c: 1 2 3 <class 'int'> <class 'int'> <class 'int'>
str1,str2: a b <class 'str'> <class 'str'>
list_1,list_2: [1, 2, 3] ['a', 'b', 'c'] <class 'list'> <class 'list'>
dict_1,dict_2: {'电视剧': '上海滩'} {'电影': '黄飞鸿'} <class 'dict'> <class 'dict'>
# 我们发现变量的数据类型和值的类型相同
buf = 1,2,3
buf_1 = "a","b","c"
buf_2 = [1,2,3],["a","b","c"]
buf_3 = {"电视剧":"上海滩"},{"电影":"黄飞鸿"}
print("buf:",buf,type(buf))
print("buf_1:",buf_1,type(buf_1))
print("buf_2:",buf_2,type(buf_2))
print("buf_3:",buf_3,type(buf_3))
# 打印结果如下
buf: (1, 2, 3) <class 'tuple'>
buf_1: ('a', 'b', 'c') <class 'tuple'>
buf_2: ([1, 2, 3], ['a', 'b', 'c']) <class 'tuple'>
buf_3: ({'电视剧': '上海滩'}, {'电影': '黄飞鸿'}) <class 'tuple'>
# 我们发现所有变量的数据类型都是元组tuple
总结:如果=号两边变量的数量和值的数量相等,那么变量的数据类型和值的数据类型相同,如果用一个变量接收用逗号","分隔的多个值时,变量最终的数据类型是tuple元组。
通过解构的方式打印字典的键和值
dict_ = {"电视剧":"水浒传","电影":"黄飞鸿"}
for key_,val_ in dict_.items(): # 通过结构的方式打印键和值
print(key_,val_)
# 打印内容如下:
电视剧 水浒传
电影 黄飞鸿
set集合:无序列表,集合的特性是没有重复数据。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典的,还有set集合的值必须是不可变的如:整型、字符串、元祖不能是列表,字典等可被修改的数据。如下操作:
set_1 = {1,2,3} # 正确
set_2 = set() # 定义一个空列表
set_3 = {"a","b","c"} # 正确
set_4 = {True,False} # 正确
set_5 = {1,2,"a",(1,2,3)} # 正确
set_6 = {1,2,"a",[1,2,3]} # 错误的赋值方式,list是可变的
print(set_3)
# 打印内容如下:
TypeError: unhashable type: 'list'
set_7 = {1,2,"a",{"字典":"值"}} # 错误的赋值方式,dict是可变的
print(set_7)
# 打印内容如下:
TypeError: unhashable type: 'dict'
set_8 = {1,2,"a",{5,7,9}} # 错误的赋值方式,set是可变的
print(set_3)
# 打印内容如下:
TypeError: unhashable type: 'set'
set集合中常用的方法:
新增
add():向集合中添加数据,参数必须是不可改变的,参数类型参考set的赋值。
set_ = {1,2,3}
set_.add(4)
print(set_)
#打印如下内容:
{1, 2, 3, 4}
set_ = {1,2,3}
list_ = ["a","n"]
set_.add(list_) # 因为列表是可变的,所以不能用作集合的值
# 打印内容如下:
TypeError: unhashable type: 'list'
更新
update(可迭代对象):向集合中添加可迭代数据。
set_1 = {1,2,"a"}
set_1.update([10,20,3])
set_1.update(("defghigk"))
set_1.update((10,20,30))
set_1.update({"字典":"键"})
print(set_1)
# 打印内容如下
{1, 2, 3, 10, 'g', 'h', 'd', 'a', 'i', 'k', 20, 'f', 'e', '字典', 30}
删除:
set_3 = {1,2,"a"}
del set_3 # 因为集合是无序的没有下标,所以用del只能删除集合
pop():随机删除一个元素(测试如果有0,默认先删除0,其它随机)
set_3 = {1,2,"a"}
set_3.pop() # 随机删除一个元素
print(set_3)
# 打印内容如下:
{2, 'a'}
remove(元素):根据元素删除元素,如果删除一个没有的元素会报错
set_3 = {1,2,"a"}
set_3.remove(2)
print(set_3)
# 打印内容如下:
{1, 'a'}
集合的其它操作:
交集:两个集合里面都存在的数据,可以使用&或者使用函数intersection来获取两个集合的交集.
set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 & set_2 # 通过&符号获取set_1和set_2的交集
print(set_3)
# 打印内容如下:
{2, 3}
# 通过函数intersection()获取交集
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.intersection(set_2) # 通过函数获取set_1和set_2的交集 print(set_3)
# 打印内容如下:
{'a', 'c'}
并集:将两个集合进行合并(集合是去重复的).使用|符号或者使用union()函数
set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 | set_2 # 使用|符号获取两个集合的并集
print(set_3)
# 打印内容如下:
{1, 2, 3, 4, 40, 10}
# 通过函数union()获取两个集合的并集
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.union(set_2) # 使用union()函数获取两个数的并集
print(set_3)
# 打印内容如下:
{'b', 'z', 'a', 'c', 'd'}
差集:从第一个集合中减去第一个集合和第二个集合共同存在的元素.使用符号-或者使用函数difference()来实现
set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 - set_2 # 通过符号-将set_1和set_2共同存在的元素从set_1中删除,如果set_2在前就从set_2中删除
print(set_3)
# 打印内容如下:
{1, 4}
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.difference(set_2) # 通过函数difference()实现
print(set_3)
# 打印内容如下:
{'d', 'b'}
反交集:将两个集合进行合并,并去除相同的元素,使用符号^或者symmetric_difference
set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 ^ set_2 # 使用^符号实现
print(set_3)
# 打印内容如下:
{1, 4, 40, 10}
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.symmetric_difference(set_2) # 使用函数实现
print(set_3)
# 打印内容如下:
{'z', 'b', 'd'}
子集:一个集合是否被另一个集合所包含.如果被另一个集合包含返回True,否则返回False.使用<符号或者issubset()
set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 < set_2 # 使用<符号实现
print(set_3)
# 打印内容如下:
False
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a","b","d","e"}
set_3 = set_1.issubset(set_2) # 使用函数实现
print(set_3)
# 打印内容如下:
True
超级:与子集相反,判断一个集合是否包含另一个集合,如果包含另一个集合返回True否则返回False.使用符号>或者issuperset()
set_1 = {1,2,3,4,10,50,40}
set_2 = {10,2,40,3}
set_3 = set_1 > set_2 # 使用>符号
print(set_3)
# 打印内容如下:
True
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a","b","d","e"}
set_3 = set_1.issuperset(set_2) # 使用函数实现
print(set_3)
# 打印内容如下:
False
frozenset(可迭代对象):返回一个冻结的集合.被冻结的集合不能进行修改,删除,添加等操作.如果不写参数,则返回一个冻结的空的集合.参数是可迭代对象所以可以是列表,字典等
下面是一些简单的事例:
set_1 = {"a","b","c","d"}
dic_1 = {"字典":"值"}
list_1 = [1,2,3]
set_2 = frozenset(set_1)
dic_2 = frozenset(dic_1)
list_2 = frozenset(list_1)
print(type(set_2),set_2)
print(type(dic_2),dic_2) # 字典只能看键不能看值,很多方法都不能用
print(type(list_2),list_2) # 列表的下标也不能使用,大多数函数不能用
# 打印内容如下:
<class 'frozenset'> frozenset({'b', 'd', 'a', 'c'})
<class 'frozenset'> frozenset({'字典'})
<class 'frozenset'> frozenset({1, 2, 3})