国产成人AV无码一二三区,少女1到100集,国产精品久久久久精品综合紧,巜公妇之诱感肉欲HD在线播放

文章 > Python高级 > 深入理解Python的set和dict

深入理解Python的set和dict

头像

silencement

2019-07-15 10:47:202957浏览 · 0收藏 · 0评论

dict常用操作

引言

clear(): 清空字典

copy(): 返回一个浅拷贝

fromkeys(): 将可迭代对象中的每一个元素作为key和同一个value拼成字典

get(): 根据key返回value,若无对应的键值对,则返回None,也可以指定默认返回值,和索引访问相比,不会产生异常。

items():返回一个dict_items类型,支持迭代,键值对以元组形式组织

setdefault(): 获取key对应的value值,先调用get(),若不存在该键值对,则添加

update(): 合并字典,或键值对元组构成的可迭代对象

使用案例

# 1. clear()
d = {name:"MetaTian", age:"22"}
d.clear()

# 2. copy()
new_dict = d.copy()
new_dict["age"] = 18

print(new_dict)
print(d)
# resutl:
# {'age': 18, 'name': 'MetaTian'}
# {'age': '22', 'name': 'MetaTian'}

# 3. fromkeys()
d = dict.fromkeys(range(3), "MetaTian")
print(d)
# result:
# {0: 'MetaTian', 1: 'MetaTian', 2: 'MetaTian'}

# 4. get()
print(d.get(2))
print(d.get(3))
print(d.get(3, "null"))

# result:
# MetaTian
# None
# null

# 5. items()
print(type(d.items()))
print(d.items())
# result:
# <class 'dict_items'>
# dict_items([(0, 'MetaTian'), (1, 'MetaTian'), (2, 'MetaTian')])

# 6. setdefault()
d = {}
value = d.setdefault("name", "MetaTian")  # 如果无 name 这个 key,则添加
print(value, d)
# result:
# MetaTian {'name': 'MetaTian'}

# 7. update()
d1 = {1:"a"}
d2 = {2:"b"}

d1.update(d2)
d2.update([(3, "c"), (4, "d")])

print(d1)
print(d2)
# result:
# {1: 'a', 2: 'b'}
# {2: 'b', 3: 'c', 4: 'd'}

set和frozenset

引言

set是可变集合,frozenset是不可变集合

集合中的元素无序,不重复

使用案例

"""
通过 set(Iterable) 来构建出可变集合对象
通过 frozenset(Iterable) 构建不可变集合对象
"""
s = set("12345666")
fs = frozenset(['a', 'b', 'c', 'a'])    # 不可变类型,可以作为 dict 的 key
print(s)
print(fs)

# result:
# {'6', '1', '4', '5', '3', '2'}
# frozenset({'b', 'a', 'c'})

"""
向 set 中添加元素
add()
update()
"""
s1, s2 = set("123"), set("234")
s1.update(s2)
s2.add('5')

print(s1)
print(s2)

# result:
# {'1', '2', '3', '4'}
# {'2', '3', '5', '4'}

"""
集合的运算
- 差
& 交
| 并
"""
s1, s2 = set("123"), set("234")
print(s1 - s2)
print(s1 & s2)
print(s1 | s2)

# result:
# {'1'}
# {'2', '3'}
# {'3', '1', '2', '4'}

dict和set的实现原理

引言

dict和set的查找性能远远大于list

dict和set底层通过散列表存储,因此也要求dict的key是可哈希的,不可变对象都是可哈希的

哈希的原理.

以字典为例.

存储之前要通过哈希函数来计算key的值,得到存储索引,如果得到的结果已经被使用,要处理冲突,重新计算后再进行存储

自定义的类通过实现__hash__(),就可以存储在dict和set中.

因此,具体的存储顺序和元素添加的顺序可能有关.

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

成色P31S是国精产品吗| 《哺乳》电影完整版观看| 《疯狂72小时》韩剧| 啵啵影院| 无码亚洲一区二区三区| 国产X9X9X9X9X9X任意..| 特级毛片《武则天》| 我和两个小婕子做过爱| 三年大片免费观看完整版高清| 少妇大屁股白浆流出白浆| 朋友的妈妈7中字谜| 《美国伦理4女警》| 《情欲按摩院》未删减版| 美女 衣服全部没| 风车动漫网| 哈尼克孜| B级文件| 医生一直揉白带湿漉漉的正常吗| 《炸裂吧!巨棒》免费阅读漫画| 粗大的蘑菇头刮得又红又肿怎么办 | 吃瓜群众在线爆料免费观看 | 出差3| 成全视频观看免费高清中国电视剧| 水是什么意思?| 《部长你别这样》大结局 | 《大尺度吃奶做爰》电影| 美国禁忌结局1-4| 榜上佳婿电视剧全集免费观看高清| 丁香花影院免费观看电视剧哈尔滨| 美女和男生一起努力的生孩子视频.. | 久久婷婷五月综合色国产香蕉| 深入无人区短剧免费高清观看 | 姐姐片多多免费高清电视剧| 欧美片《肉欲进入》| 妈妈装睡配合孩子阴阳调和| 《请好好疼爱里面》免费观看 | 西游记| 美女和帅哥一起努力生产豆浆 | 《办公室高潮秘书2》电影| 免费的行情网站WWW网页版| 老翁玩嫩媳