首頁技術(shù)文章正文

Python的四種必會的內(nèi)置數(shù)據(jù)結(jié)構(gòu)

更新時間:2018-12-13 來源:黑馬程序員 瀏覽量:

對于每種編程語言一般都會規(guī)定一些容器來保存某些數(shù)據(jù),就像java的集合和數(shù)組一樣python也同樣有這樣的結(jié)構(gòu)

而對于python他有四個這樣的內(nèi)置容器來存儲數(shù)據(jù),他們都是python語言的一部分可以直接使用而無需額外的導(dǎo)入

一.列表(list)

  列表一種跟java和c中的數(shù)據(jù)很像的一種數(shù)據(jù)結(jié)構(gòu),他都是保存一系列相似,且有序元素的集合,不過不同的是列表中的元素可以不是同一種數(shù)據(jù)類型,且列表的長度是可變的

  可以動態(tài)的增加可減少這一點則有點像java中的stringBuilder對象,列表中有一點值得注意的是在對列表進(jìn)行復(fù)制是,不能簡單的使用賦值語句,這樣會使得兩個變量同時指向一個列表,當(dāng)一個改變時另一個變量的值也會改變,正確的復(fù)制方法是用copy()方法來進(jìn)行復(fù)制

  關(guān)于一個存儲結(jié)構(gòu)增刪查看則其必備的功能:

    1.列表元素的增加

      append的方法是將所要加的元素直接加到先前列表的末尾的方法,在增加的同時還會使得列表得長度增加

      extend方法是將一個列表中得所有元素加拓展到另一個列表的末尾將兩個列表合并為一個列表

      insert方法是將一個元素插入到指定的位置,但是值得注意的是insert方法不能插到列表的末尾

    2.列表元素的刪除

      remove刪除列表中指定的值,如果列表中沒有remove參數(shù)中指定的值解釋器將會報錯

      pop刪除指定索引位置對應(yīng)的對象,如果pop方法中沒有參數(shù)是則其默認(rèn)的是刪除列表的最后的一個對象,該方法的返回值就是對應(yīng)刪除的對象,若其指定的索不存在      時解釋器同樣會報錯

    下面通過一個簡單的例子來說明以上方法的使用:

#在 Don't panic變?yōu)?on tap

phrase="Don't panic"


plist=list(phrase)  #將phrase表示的字符串轉(zhuǎn)化為列表



print(phrase)       #將該字符串輸出

print(plist)        #結(jié)果為['D', 'o', 'n', "'", 't', ' ', 'p', 'a', 'n', 'i', 'c']


plist.remove("'")   #將‘在列表中刪除


for i in range(3):

    plist.pop()     #將列表末尾的3個字符給刪除,'n','i','c'


plist.pop(0)        #將plist中索引對應(yīng)的對象刪除,也就是D


#此時list中的值為['o', 'n', 't', ' ', 'p', 'a']


plist.extend([plist.pop(5),plist.pop(4)]) #將p和a的位置交換


plist.insert(2,plist.pop(3)) #將空格插入到對應(yīng)索引為2的對象前


phrase =''.join(plist) #將列表轉(zhuǎn)化為字符串


print(phrase)

 3.列表元素的查看:
      值得說明的是列表的查看和數(shù)組相似,都支持下標(biāo)查看不過不同的是列表的查看功能比數(shù)組更多

      a.中括號加下標(biāo)可以查看列表中的任意元素且元素的下標(biāo)也都是從0開始的,這點與數(shù)組相同,但不同的是數(shù)組中的下標(biāo)不能為負(fù)數(shù),而列表可以  

      其表示的是從右到左,而正數(shù)則是從左到右

      b.列表中支持切片查看,也就是查看某一段元素其用法為:list[開始位置:結(jié)束位置:步長]其中所有元素都可以省,只需要在括號中有一個元素即可例如:

       list[: :2]表示開始為0,結(jié)束為列表尾,步長為2

   下面我們?nèi)稳灰砸欢魏唵蔚拇a來展示其用法:

phrase="Don't panic"


plist=list(phrase)

new_phase=''.join(plist[1:3])#在列表中截取on

print(new_phase)

new_phase=new_phase+''.join([plist[5],plist[4],plist[7],plist[6]])



#切片的實例,以及負(fù)數(shù)


plist[-1] # c


temp =plist[5:1:-1] #[' ', 't', "'", 'n']當(dāng)步長為負(fù)數(shù)時其結(jié)果時從右到左遍歷

temp2=plist[::2]#['D', 'n', 't', 'p', 'n', 'c'],從頭遍歷到尾步長為2

二.字典(dict)

  字典使用來保存一個鍵值對集合,其中每個唯一的鍵都有一個與之對應(yīng)的值,通常我們把字典稱為關(guān)聯(lián)數(shù)組,如果你學(xué)過java的那么對字典就不會陌生了因為它其實就是java中的set集合,python的字典是無序的它不會保留你插入時的順序,同時由于字典使用的是一種高度優(yōu)化的散列算法所以即使是沒有順序字典一樣能快速的訪問與一個鍵相關(guān)的值

1字典的定義:

其結(jié)構(gòu)為{鍵1:值1,鍵2:值2},可以看出字典的開始和結(jié)束都是用大括號鍵和值用冒號隔開,不同鍵值對之間用逗號分隔,其中值可以為列表,另一個字典

2字典的增加:

字典時一個動態(tài)的集合他可以在鍵對不存在時插入新的鍵值對,但是字典中鍵必須進(jìn)行初始化后才可以引用例如:在一個商店中你不知到你的商店中的蘋果又沒  有時

你不可以直接的使用蘋果這個值而當(dāng)你像添加時也需要查明商店中是否有這樣物品,對于字典則無需這樣。因為字典已經(jīng)分裝好了一個setdefault()方法只需直接調(diào)用即可

下面用一段簡單代碼展示:

#字典的添加鍵值對

fruit={}

#當(dāng)直接使用不存在的鍵值對時


fruit['apple']+=1 #沒有對該鍵初始化而直接使用會出現(xiàn)keyError


#當(dāng)不使用setdefault方法時動態(tài)的增加鍵值對

if 'apple' not in fruit:

    fruit['apple']=0 #初始化鍵值

fruit['apple']+=1 #增加蘋果的量

print(fruit['apple'])


#使用setdefault時,其實就是設(shè)置一個默認(rèn)值,確保使用時這個使用的鍵存在即可


fruit.setdefault('apple',0)#當(dāng)鍵存在時這個語句沒有任何作用,相當(dāng)于上面選擇的分裝

fruit['apple']+=1

print(fruit['apple'])

3字典的遍歷:

對于一個集合來說我們一般都會采用集合來遍歷其中的所有元素但是對于字典來說單單只用循環(huán)的話并不夠方便因為僅僅只用循環(huán)的話解釋器只會處理字典的鍵

對于其值任然需要用鍵來查值,對于這種問題python提供了一個items()的方法使得可以直接使用循環(huán)變量來訪問字典的鍵和值

下面通過一段簡單的代碼說明:

fruit={'apple':10,'pears':5,'bananas':20,'orange':4}

#直接使用for循環(huán)遍歷

for i in fruit:

    print("種類",i,"數(shù)量",fruit)

#使用items方法遍歷

for i,v in fruit.items():

    print("種類",i,"數(shù)量",v)

四.元組(tuple)

1元組的定義:

元組與列表密切相關(guān)列表是用中括號定義而元組則是用小括號定義(元素1,元素2,元素3,.....),值得注意的是當(dāng)只有一個對象是并不能僅僅(對象)這樣定義并不是元組,正確的定義方法是(對象,)這樣才是元組

在最后我有必要說明一下:在這四個內(nèi)置結(jié)構(gòu)為空時的解釋器的表示方法:1.空列表[] 2.空字典{} 3.空集合set() 4.空元組()

   
作者:黑馬程序員人工智能+Python培訓(xùn)學(xué)院    
首發(fā):http://python.itheima.com/


分享到:
在線咨詢 我要報名
和我們在線交談!