文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python字典、集合之高山流水

2023-01-30 23:19

关注

字典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})

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯