Python 7 : 使用dict 和 set

dict

python內(nèi)置了字典:dict糟趾,使用鍵-值(key-value)存儲(chǔ)慌植。具有極快的查找速度甚牲。
用Python寫一個(gè)dict如下:

>>> d = {"Michael": 95, "Bob": 75, "Trancy": 85}
>>> d["Michael"]
95

把數(shù)據(jù)放入dict的方法义郑,除了初始化時(shí)指定外,還可以通過key放入:

>>> d["Adam"] = 67
>>> d["Adam"]
67

由于一個(gè)key只能對(duì)應(yīng)一個(gè)value丈钙,所以非驮,多次對(duì)一個(gè)key放入value,后面的至?xí)亚懊娴闹禌_掉:

>>> d["Jack"] = 90
>>> d["Jack"]
90
>>> d["Jack"] = 88
>>> d["Jack"]
88

如果key不存在雏赦,dict就會(huì)報(bào)錯(cuò)
要避免key不存在劫笙,有兩種方法,一是通過in 判斷:

>>> "Thomas" in d 
False

二是通過dict提供的get()方法星岗,如果key不存在填大,可以返回None。
注意:返回None的時(shí)候Python的交互環(huán)境不顯示結(jié)果俏橘。

要?jiǎng)h除一個(gè)key允华, 用pop(key)方法,對(duì)應(yīng)的value也會(huì)從dict中刪除:

>>> d.pop("Bob")
75
>>> d
{"Michael":96, "Trancy": 85}

注意:dict內(nèi)部存放的順序可key放入的順序是沒有關(guān)系的寥掐。

  • 和list比較靴寂,dict有以下幾個(gè)特點(diǎn):
    1.查找和插入的速度極快,不會(huì)隨著key的增加而變慢召耘。
    2.需要占用大量?jī)?nèi)存百炬,內(nèi)存浪費(fèi)多。
  • 而list相反:
    1.查找個(gè)插入的時(shí)間隨著元素的增加而增加污它;
    2.占用空間小剖踊,浪費(fèi)內(nèi)存很少。

所以轨蛤,dict是用空間換時(shí)間的一種方法蜜宪。

正確使用dict非常重要,需要牢記的第一條就是dict的可以必須是不可變對(duì)象祥山。

set

set和dict類似圃验,也是一組key的集合,但不存儲(chǔ)value缝呕。由于不能重復(fù)澳窑,所以,set里供常,沒有重復(fù)的key摊聋。
要?jiǎng)?chuàng)建一個(gè)set,需要提供一個(gè)list作為輸入集合:

>>> s = set([1,2,3])
>>> s 
{1,2,3}

注意栈暇,傳入的參數(shù)[1,2,3]是一個(gè)list麻裁,而顯示的{1,2,3}只說明set內(nèi)部有1,2,3這3個(gè)元素,顯示的順序也不表示set是有序的。
重復(fù)元素在set中自動(dòng)被過濾:

>>> s = set([1,1,1,2,2,3,3])
>>> s 
{1,2,3}

通過add(key)方法可以添加元素到set中煎源,可以重復(fù)添加色迂,但不會(huì)有效。
通過remove(key)方法可以刪除元素手销。
set可以看成數(shù)學(xué)上的無序和無重復(fù)元素的集合歇僧,因此,兩個(gè)set可以做數(shù)學(xué)意義上的交集锋拖,并集等操作:

>>> s1 = set([1,2,3])
>>> s2 = ste([2,3,4])
>>> s1 & s2
{2,3}
>>> s1 | s2
{1,2,3,4}

不可變對(duì)象诈悍,str,對(duì)str進(jìn)行操作:

>>> a = "abc"
>>> a.replace('a','A')
'Abc'
>>> a
'abc'
>>> a = 'abc'
>>> b = a.replace('a','A')
>>> b
'Abc'
>>> a
'abc'
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末兽埃,一起剝皮案震驚了整個(gè)濱河市侥钳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌柄错,老刑警劉巖慕趴,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異鄙陡,居然都是意外死亡冕房,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門趁矾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來耙册,“玉大人,你說我怎么就攤上這事毫捣∠曜荆” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蔓同,是天一觀的道長(zhǎng)饶辙。 經(jīng)常有香客問我,道長(zhǎng)斑粱,這世上最難降的妖魔是什么弃揽? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮则北,結(jié)果婚禮上矿微,老公的妹妹穿的比我還像新娘。我一直安慰自己尚揣,他們只是感情好涌矢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著快骗,像睡著了一般娜庇。 火紅的嫁衣襯著肌膚如雪塔次。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天名秀,我揣著相機(jī)與錄音俺叭,去河邊找鬼。 笑死泰偿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蜈垮。 我是一名探鬼主播耗跛,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼攒发!你這毒婦竟也來了调塌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤惠猿,失蹤者是張志新(化名)和其女友劉穎羔砾,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體偶妖,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡姜凄,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了趾访。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片态秧。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖扼鞋,靈堂內(nèi)的尸體忽然破棺而出申鱼,到底是詐尸還是另有隱情,我是刑警寧澤云头,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布捐友,位于F島的核電站,受9級(jí)特大地震影響溃槐,放射性物質(zhì)發(fā)生泄漏匣砖。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一昏滴、第九天 我趴在偏房一處隱蔽的房頂上張望脆粥。 院中可真熱鬧,春花似錦影涉、人聲如沸变隔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽匣缘。三九已至猖闪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間肌厨,已是汗流浹背培慌。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留柑爸,地道東北人吵护。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像表鳍,于是被迫代替她去往敵國和親馅而。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 什么是dict 我們已經(jīng)知道譬圣,list 和 tuple 可以用來表示順序集合瓮恭,例如,班里同學(xué)的名字: ['Adam...
    _王子_閱讀 1,285評(píng)論 0 1
  • 0. 序言 python 是一門腳本語言:封裝性強(qiáng)厘熟,語法簡(jiǎn)潔屯蹦,開發(fā)效率高,只用函數(shù)open就可以打開一個(gè)txt文件...
    付凱強(qiáng)閱讀 1,228評(píng)論 0 5
  • 一绳姨、python 變量和數(shù)據(jù)類型 1.整數(shù) Python可以處理任意大小的整數(shù)登澜,當(dāng)然包括負(fù)整數(shù),在Python程序...
    績(jī)重KF閱讀 1,705評(píng)論 0 1
  • 2009年6月18 星期日 晴 今天飘庄,好友來訪帖渠,吃完飯我們一起去逛銀座。她家的孩子和女兒一樣大竭宰,上...
    ytt木子閱讀 134評(píng)論 0 0
  • 小兒健脾和胃保健推拿法主要是針對(duì)脾空郊、胃功能較差小兒的一種保健推拿方法。 小兒胃口差切揭、不愛吃飯是困擾很多家長(zhǎng)的問題狞甚。...
    米妮老師說兒推閱讀 389評(píng)論 0 1