第13講python類型層次及其他_第1頁
第13講python類型層次及其他_第2頁
第13講python類型層次及其他_第3頁
第13講python類型層次及其他_第4頁
第13講python類型層次及其他_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

課程提綱:Python重訪類型分類及其他

重訪類型分類對(duì)象靈活性引用VS拷貝比較、相等性和真值Python的類型層次內(nèi)置類型陷阱1重訪類型分類在了解了Python中核心內(nèi)置類型以后,下表對(duì)所有類型重新加以分類。對(duì)象根據(jù)它所屬的類別共享操作。

對(duì)象分類對(duì)象類型分類是否可變數(shù)字?jǐn)?shù)值否字符串序列否列表序列是字典對(duì)應(yīng)是元組序列否文件擴(kuò)展N/A2對(duì)象靈活性列表、字典和元組可以包含任何種類的對(duì)象列表、字典和元組可以任意嵌套列表和字典可以動(dòng)態(tài)地?cái)U(kuò)大和縮小例子:>>>L=['abc',[(1,2),([3],4)],5]>>>L[1][(1,2),([3],4)]>>>L[1][1]([3],4)>>>L[1][1][0][3]>>>L[1][1][0][0]33引用VS拷貝在Python中,賦值操作總是儲(chǔ)存對(duì)象的引用,而不是這些對(duì)象的拷貝。在實(shí)際應(yīng)用中,如果某個(gè)引用在原處修改了可變對(duì)象時(shí)可能就會(huì)影響程序中其他地方對(duì)相同對(duì)象的其他引用,這一點(diǎn)很重要。如果不想這樣做,就需要明確地告訴Python復(fù)制該對(duì)象。例如:>>>X=[1,2,3]>>>L=['a',X,'b']>>>D={'x':X,'y':2}變量名對(duì)象LXD123>>>X[1]='surprise'>>>L['a',[1,'surprise',3],'b']>>>D{'y':2,'x':[1,'surprise',3]}3引用VS拷貝

Python中,在傳遞大型對(duì)象時(shí)如果的確需要拷貝,那么可以明確要求。沒有限制條件的分片表達(dá)式能夠復(fù)制序列字典copy方法能夠復(fù)制字典有些內(nèi)置函數(shù)(例如list)能夠生成拷貝(list(L))copy標(biāo)準(zhǔn)庫模塊能夠生成完整拷貝例如:>>>L=[1,2,3]>>>D={'a':1,'b':2}>>>A=L[:]>>>B=D.copy()>>>A[1]='Ni'>>>B['c']='spam'>>>L,D([1,2,3],{'a':1,'b':2})>>>A,B([1,'Ni',3],{'a':1,'c':'spam','b':2})4比較、相等性和真值所有的Python對(duì)象也可以支持比較操作—測(cè)試相等性、相對(duì)大小等。Python的比較總是檢查復(fù)合對(duì)象的部分,直到可以得出結(jié)果為止。事實(shí)上,當(dāng)嵌套對(duì)象存在時(shí),Python能夠自動(dòng)遍歷數(shù)據(jù)結(jié)構(gòu),并從左到右遞歸地應(yīng)用比較,要多深就走多深?!?=”:操作符測(cè)試值的相等性。(遞歸地比較所有內(nèi)嵌對(duì)象)“is”:表達(dá)式測(cè)試對(duì)象的一致性。(測(cè)試二者是否是同一個(gè)對(duì)象,檢查內(nèi)存地址)例如:>>>L1=[1,('a',3)]>>>L2=[1,('a',3)]>>>L1==L2,L1isL2(True,False)>>>s1='alongerstring'>>>s2='alongerstring'>>>s1==s2,s1iss2(True,False)一般來說,在Python不同的類型的比較方法如下:數(shù)字通過相對(duì)大小進(jìn)行比較。字符串是按照字典順序,一個(gè)字符接一個(gè)字符地對(duì)比進(jìn)行比較。列表和元組從左到右對(duì)每部分的內(nèi)容進(jìn)行比較。字典通過排序之后的(鍵、值)列表進(jìn)行比較。5Python的類型層次數(shù)字整數(shù)FloatComplexSetDecimalIntegerLongBoolean集合序列映射不可變可變DictionaryStringListUnicodeTupleModuleInstanceFileNoneTypeCodeFrameTraceback其他內(nèi)部細(xì)節(jié)FunctionClass方法BoundUnbound可調(diào)用6內(nèi)置類型陷阱(1)賦值生成引用,而不拷貝:>>>L=[1,2,3]>>>M=['x',L,'Y']>>>M['x',[1,2,3],'Y']>>>L[1]=0>>>M['x',[1,0,3],'Y']>>>L=[1,2,3]>>>M=['x',L[:],'Y']>>>L[1]=0>>>L[1,0,3]>>>M['x',[1,2,3],'Y'](2)重復(fù)能夠增加層次深度:>>>L=[4,5,6]>>>X=L*4>>>Y=[L]*4>>>X[4,5,6,4,5,6,4,5,6,4,5,6]>>>Y[[4,5,6],[4,5,6],[4,5,6],[4,5,6]]>>>L[1]=0>>>X[4,5,6,4,5,6,4,5,6,4,5,6]>>>Y[[4,0,6],[4,0,6],[4,0,6],[4,0,6]]6內(nèi)置類型陷阱(3)留意循環(huán)數(shù)據(jù)結(jié)構(gòu):無論何時(shí)Python在對(duì)象中檢測(cè)到循環(huán),都會(huì)打印成[…],而不會(huì)陷入無限循環(huán)>>>L=['grail']>>>L.append(L)>>>L['grail',[...

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論