python入门系列:深入Python的set和dict

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:

#

# 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中

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

注:喜欢python + qun:839383765 可以获取Python各类免费最新入门学习资料!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容