詳解python的四種內(nèi)置數(shù)據(jù)結(jié)構(gòu)
對于每種編程語言一般都會規(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來展示其用法:
#在 Don't panic變?yōu)?on tap 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
事實上對于存儲類似對象的時候我們一般是使用列表,而對于那種有結(jié)構(gòu)的數(shù)據(jù)是列表就顯得不那么實用了因為列表很難存儲數(shù)據(jù)之間的結(jié)構(gòu)
所以對于那種結(jié)構(gòu)化的數(shù)據(jù)我們一般采用字典來存儲
二.字典(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[i]) #使用items方法遍歷 for i,v in fruit.items(): print("種類",i,"數(shù)量",v)
4字典的元素刪除:
python的字典刪除有三種方法,一種是clear()是刪除字典中的所有元素,二是pop()根據(jù)pop中的參數(shù)刪除與其鍵相同的鍵值對,三是popitem()隨機(jī)刪除字典中的元素
對于有結(jié)構(gòu)的數(shù)據(jù)我們使用字典時會顯得非常方便,因為他不僅可以保存結(jié)構(gòu),還可以保證記錄不重復(fù),但是對于那些沒有結(jié)構(gòu)的數(shù)據(jù)我們又不希望他們重復(fù)時,字典和列表顯然都不適合我們使用了,這時我們就會想到使用集合了
三.集合(set)
1集合的定義:
{元素1,元素2,元素3.....}和字典一樣都是用大括號定義,不過不同的是其中沒有冒號分割,還有一種定義方法是向set()函數(shù)中傳遞任意一個序列(如一個字符串set('fsdaf'))
2集合的運(yùn)算:
python中的集合同于數(shù)學(xué)中的集合同樣有交,并,差等運(yùn)算其中并算提供方法union(),差集方法difference()不過這里不同的是只能顯示使用該方法的集合中不同于另一個集合的所有元素,交集的方法intersection()顯示相同的元素
下面用代碼來實現(xiàn)上述方法:
#集合的運(yùn)算 temp={'a','e','i','o','u'} temp2=set("fda"); #交運(yùn)算 result=temp.intersection(temp2)#{'a'} #并運(yùn)算 result=temp.union(temp2)#{'a', 'o', 'f', 'd', 'u', 'e', 'i'} #差運(yùn)算 result=temp.difference(temp2)#{'o', 'e', 'u', 'i'}
我們知道變量有兩種一種是變量一種是常量,變量的值可以重新賦予,而常量的值則不行,在python中我們同樣有一個不變的結(jié)構(gòu)叫做元組
四.元組(tuple)
1元組的定義:
元組與列表密切相關(guān)列表是用中括號定義而元組則是用小括號定義(元素1,元素2,元素3,.....),值得注意的是當(dāng)只有一個對象是并不能僅僅(對象)這樣定義并不是元組,正確的定義方法是(對象,)這樣才是元組
在最后我有必要說明一下:在這四個內(nèi)置結(jié)構(gòu)為空時的解釋器的表示方法:1.空列表[] 2.空字典{} 3.空集合set() 4.空元組()
以上所述是小編給大家介紹的python的四種內(nèi)置數(shù)據(jù)結(jié)構(gòu)詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Python常見數(shù)據(jù)結(jié)構(gòu)之棧與隊列用法示例
- Python數(shù)據(jù)結(jié)構(gòu)之棧、隊列及二叉樹定義與用法淺析
- Python中的函數(shù)式編程:不可變的數(shù)據(jù)結(jié)構(gòu)
- python數(shù)據(jù)結(jié)構(gòu)之線性表的順序存儲結(jié)構(gòu)
- python數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)之實現(xiàn)線性表的順序
- Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例
- Python數(shù)據(jù)結(jié)構(gòu)之哈夫曼樹定義與使用方法示例
相關(guān)文章
python基于?Web?實現(xiàn)?m3u8?視頻播放的實例
這篇文章主要介紹了python基于?Web?實現(xiàn)?m3u8?視頻播放的實例的相關(guān)資料,需要的朋友可以參考下2023-06-06python實現(xiàn)爬蟲抓取小說功能示例【抓取金庸小說】
這篇文章主要介紹了python實現(xiàn)爬蟲抓取小說功能,結(jié)合具體實例形式分析了使用Python爬蟲抓取金庸小說的具體操作技巧,需要的朋友可以參考下2019-08-08python執(zhí)行shell獲取硬件參數(shù)寫入mysql的方法
這篇文章主要介紹了python執(zhí)行shell獲取硬件參數(shù)寫入mysql的方法,可實現(xiàn)對服務(wù)器硬件信息的讀取及寫入數(shù)據(jù)庫的功能,非常具有實用價值,需要的朋友可以參考下2014-12-12Windows上配置Emacs來開發(fā)Python及用Python擴(kuò)展Emacs
這篇文章主要介紹了Windows上配置Emacs來開發(fā)Python及用Python擴(kuò)展Emacs的方法,Emacs與Vim并稱為開發(fā)者手中最強(qiáng)大的兩款文本編輯器,需要的朋友可以參考下2015-11-11Python3.6實現(xiàn)根據(jù)電影名稱(支持電視劇名稱),獲取下載鏈接的方法
這篇文章主要介紹了Python3.6實現(xiàn)根據(jù)電影名稱(支持電視劇名稱),獲取下載鏈接的方法,涉及Python爬蟲與正則相關(guān)操作技巧,需要的朋友可以參考下2019-08-08Python+OpenCV實現(xiàn)基本的圖像處理操作
說到圖像處理,那必然要提到opencv模塊了。本文將從最基本的opencv模塊在圖像的基本操作上說起,利用Python+OpenCV實現(xiàn)圖像的讀取保存等,感興趣的可以了解一下2022-07-07python django 原生sql 獲取數(shù)據(jù)的例子
今天小編就為大家分享一篇python django 原生sql 獲取數(shù)據(jù)的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08