dict(key与value)和set(key)

dict和set

  • dict (字典的使用)
Python 内置了字典:dict的支持,dict全程dictionary,在其他语言中又称之为map。使用键-值(key-value)存储,具有极快的查找速度;
names = ['Michael','Bob','Tracy']
scores = [95,75,82]

  • 使用“名字”“成绩”对照表,根据名字查找成绩,使用字典类型的编辑查找方式,比较快,使用list方式查找,当量多的时候会变慢;

d = {'Michael':95,'Bob':75,'Tracy':85}
d['Michael']

byf = {'age1':18,'age2':25,'age3':35}
byf['age3']
35
  • 把数据放入dict的方法,除了初始化指定外,还可以通过key放入,当原有数据是会替换掉;
byf['age3'] = 40
byf['age3']
40
byf['age3'] = 45
byf['age3']
45
  • 如果key不存在,会报错
d['age4']
---------------------------------------------------------------------------

KeyError                                  Traceback (most recent call last)

<ipython-input-26-3c94077f8622> in <module>()
----> 1 d['age4']


KeyError: 'age4'
要避免key不存在的错误,有两种方法,
  • 一是通过in来判断key是否存在
'test' in byf
False
'test' in d
False
  • 二是通过dict给出的 get() 方法来判断,如果key不存在,返回none,或者自己指定的value;
byf.get('test') ###无返回值
byf.get('test',-1) ###指定的value值
-1
  • 要删除一个key,使用pop(key)删除,对应的值也会被删除;
d
{'Michael': 95, 'Bob': 75, 'Tracy': 85}
d.pop('Bob')
75
d
{'Michael': 95, 'Tracy': 85}
dict内部存放的顺序与key存入的顺序没有关系
和list比较,dict有一下几个特点:
1、查找和插入速度快,不会碎key的值增加而变慢
2、需要占用大量的内存,内存浪费较多
list正与dict相反:
1、查找个插入的时间随着key的增加而变慢
2、占用内存小,浪费内存少

dict 是由空间换区时间的方法
dict可以用在很多高速查找的地方,正确使用dict非常重要,需要牢记的是 dict的key是不可变对象;

key = [1,2,3]
d[key] = 'a list'
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-39-0cee50e7aa49> in <module>()
      1 key = [1,2,3]
----> 2 d[key] = 'a list'


TypeError: unhashable type: 'list'
  • set (是一组key的集合)
在set中不存储value由与key不能重复,所以在set中没有重复的值
  • 要创建一个set,需要一个list做为输入集合,格式为 s = set($list)
s = set([1,2,3])
s
###传入的是list但不表示,set是有顺序的
{1, 2, 3}
- 重复的list元素,在set中是被过滤的掉的
s = set([1,1,2,3,4,2,3])
s
{1, 2, 3, 4}
  • 通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果
s.add(4)
s
{1, 2, 3, 4}
s.add(2)
s
{1, 2, 3, 4}
  • 通过remove(key)删除set中的元素;
s.remove(4)
s
{1, 2, 3}
  • set可以看成数学意义上的无序和无重复的元素的集合,因此两个set可以作为数学意义上的交集、并集;
s1 = set([1,2,3])
s2 = set([2,3,4])
s1 & s2
{2, 3}
s1 | s2
{1, 2, 3, 4}
set与dict的唯一区别仅在于没有存储对应的value,但是set的原理跟dict一样,所以同样不可以放入可变得对象,因为无法判断两个可变变量是否相等,set中不可有重复的元素;
  • 可变对象与不可变对象,list与str的实例
对于可变对象,比如list,内部是可以发生改变的;
a = ['c','b','a']
a
['c', 'b', 'a']
a.sort()
a
['a', 'b', 'c']
对于不可变对象str
a = 'abc'
a.replace('a','A')
'Abc'
a
'abc'
虽然字符串中有个replace( )方法,但只是重新生成了字符串替换了原来的a,将变量指向了新的字符串而已;
a = 'abc'
b = a.replace('a','A')
b
'Abc'
a
'abc'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 224,093评论 6 522
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 95,870评论 3 402
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 171,133评论 0 366
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 60,638评论 1 300
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 69,652评论 6 399
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,173评论 1 314
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,560评论 3 428
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,512评论 0 279
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,048评论 1 324
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,088评论 3 344
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,232评论 1 354
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,856评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,548评论 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,020评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,152评论 1 275
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,729评论 3 380
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,255评论 2 363