溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python中的數(shù)據(jù)結(jié)構(gòu)有哪些

發(fā)布時(shí)間:2021-01-06 16:16:43 來源:億速云 閱讀:172 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)Python中的數(shù)據(jù)結(jié)構(gòu)有哪些,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

一、序列結(jié)構(gòu)

首先介紹的數(shù)據(jù)結(jié)構(gòu)是序列結(jié)構(gòu),所謂序列,也就是元素順序是很重要的,不同元素順序的序列是不同的序列。Python中含有六種內(nèi)建的序列結(jié)構(gòu),分別是list、tuple、string、unicode、buffer、xrange。

1.1、list(列表)

list,列表是一種序列,可以看做是一種數(shù)組,但不同的于其它語言的是,Python列表中的元素可以是任何數(shù)據(jù)類型,諸如,數(shù)字、字符串等等。

下面為創(chuàng)建list結(jié)構(gòu)的幾種方式:

//1.通過中括號(hào)括起已知的元素創(chuàng)建list 
mylist = ['orange', 'apple', 1,2,3.14]; 
//2.通過中括號(hào)創(chuàng)建空list,然后用append()追加動(dòng)態(tài)元素 
mylist = []; 
mylist.append('orange'); 
//3.通過list()方法創(chuàng)建空list 
mylist = list();

選取list元素的方法:

//通過中括號(hào)加下對(duì)應(yīng)下標(biāo)選取,下標(biāo)從0開始,-1為倒數(shù)第一個(gè)元素,以此類推 
mylist[0]; 
mylist[-1];

切片是Python中序列結(jié)構(gòu)獨(dú)有的一種操作,意思是從序列中選取一個(gè)子序列,凡是序列均可切片,list是序列,所以list可以切片。切片方法:

//通過[begin:end]方式完成切片 
mylist = [1,2,3,4,5]; 
mylist[0:2]; //生成的序列為[1,2,3]

list常用方法:

  • list.append(x),在列表的末尾添加一個(gè)元素。

  • list.insert(i, x),在給定的位置插入一個(gè)元素,第一個(gè)參數(shù)是要插入的元素的索引。

  • list.remove(x),移除列表中第一個(gè)值為 x 的元素,如果沒有這樣的元素,則拋出異常。

  • list.clear(),刪除列表中所有的元素。

  • list.index(x),返回列表中第一個(gè)值為 x 的元素的從零開始的索引,如果沒有這樣的元素,則拋出異常。

  • list.count(x),返回元素 x 在列表中出現(xiàn)的次數(shù)。

  • list.reverse(),反轉(zhuǎn)列表中的元素。

機(jī)器學(xué)習(xí)

1.2、tuple(元組)

tuple,元組和列表一樣,都以看做是一種數(shù)組,元素可以是任何數(shù)據(jù)類型,甚至可以嵌套。唯一的區(qū)別是,元組內(nèi)的元素一旦創(chuàng)建,是不可修改的,也不可追加。并且元組使用小括號(hào)創(chuàng)建,同樣元組可切片,切片方法同list。

//1.通過小括號(hào)括起已知的元素創(chuàng)建tuple 
mytuple = (1, 3, 'hello!') 
//2.不可以用append()往tuple追加,因?yàn)閠uple一旦創(chuàng)建,不可變更

獲取tuple中的元素:

//和列表一樣,通過中括號(hào)加下對(duì)應(yīng)下標(biāo)選取,下標(biāo)從0開始,-1為倒數(shù)第一個(gè)元素,以此類推 
mytuple[0]; 
mytuple[-1];

1.3、string,unicode,buffer,xrange

這四個(gè)也是序列,做科學(xué)計(jì)算由于不太常用,不做太多介紹。

string可以看成是少量單個(gè)字符構(gòu)成的list,如:

mystring = 'orange'; 
mylist = ['o','r','a','n','g','e'];

由于string也是序列,所以也可以切片,切片就當(dāng)做單個(gè)字符構(gòu)成的list切片即可,很多原理類似,不做過多介紹。

unicode和string類似,不過可以支持原生unicode編碼的序列,如\\u4f60\\u597d。

buffer可以看成大量字符構(gòu)成的list。

xrange可以看成純數(shù)字構(gòu)成的list。

科學(xué)計(jì)算

二、散列結(jié)構(gòu)

所謂散列結(jié)構(gòu),區(qū)別于上述序列結(jié)構(gòu),散列結(jié)構(gòu)中,元素順序是不重要的,順序不同的散列,還是同一個(gè)散列。散列結(jié)構(gòu)有set、dict。

2.1、set(集合)

set,集合,集合是由不重復(fù)元素組成的無序的集,重點(diǎn)是不重復(fù),和數(shù)學(xué)中的集合類似。無序是散列結(jié)構(gòu)的特點(diǎn),集合是一種散列結(jié)構(gòu),所以集合也有無序的特點(diǎn)。

創(chuàng)建set的方法:

//和list很類似,可對(duì)應(yīng)參考 
//1.通過大括號(hào)括起已知的元素創(chuàng)建set 
myset = {'red','blue',2.71}; 
//2.通過set()方法創(chuàng)建空set,注意不能用{}創(chuàng)建空set,這樣創(chuàng)建的是空dict 
//3.然后用add()添加動(dòng)態(tài)元素,注意不是append 
myset = set(); 
myset.add('yellow'); 
Python的set集合可以支持并集,交集,差集,對(duì)稱差等數(shù)學(xué)運(yùn)算:

//創(chuàng)建集合a 
a = set('abracadabra'); 
//創(chuàng)建集合b 
b = set('alacazam'); 
------------------ 
print(a) 
//結(jié)果:{'a', 'r', 'b', 'c', 'd'} 
------------------ 
print(a - b); //差集 
//結(jié)果:{'r', 'd', 'b'} 
------------------ 
print(a | b); //并集 
//結(jié)果:{'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'} 
------------------ 
print(a & b); //交集 
//結(jié)果:{'a', 'c'} 
------------------ 
print(a ^ b); //對(duì)稱差 
//結(jié)果:{'r', 'd', 'b', 'm', 'z', 'l'}

set常用方法:

  • set.remove(x),移除集合中值為 x 的元素,如果沒有這樣的元素,則拋出異常。

  • set.isdisjoint(set2),判斷兩個(gè)集合是否包含相同的元素,如果沒有返回 True,否則返回 False。

  • set.issubset(set2),判斷集合set是否包含于set2

  • set.issuperset(set2),判斷集合set是否包含set2,issubset與issuperset是一對(duì)互逆操作。


2.2、dict(字典)

dict,字典,字典由鍵值對(duì)組成,具有唯一性,可變性。字典是可變對(duì)象但字典的鍵的唯一的,是不可變對(duì)象。理解字典的最好方式,就是將它看做是一個(gè) 鍵 : 值對(duì)的集合。

創(chuàng)建dict的方法:

//1.通過大括號(hào)括起鍵值對(duì)創(chuàng)建dict 
mydict = {'name':'tom','age':'24'}; 
//2.通過dict()方法創(chuàng)建dict 
mydict = dict(name = 'tom',age = 24); 
//3.通過大括號(hào)創(chuàng)建空dict,然后通過中括號(hào)添加鍵值對(duì) 
mydict = {}; 
mydict['tel'] = '1300000000';

獲取dict中的元素:

//需要已經(jīng)知道鍵的名稱,否則無法獲取,除非遍歷 
mydict.get('tel');

dict常用方法:

  • dict.copy(),拷貝出一個(gè)新的字典。

  • dict.setdefault({'sex':'man'}),有則查,無則增。

  • dict.update({'sex':'male'}),有則改,無則增。

  • dict.pop('tel'),指定刪除,參數(shù)必須要有需要?jiǎng)h除的鍵。

  • dict.clear(),清空字典。

  • dict.keys(),查詢字典中所有的鍵。

  • dict.values(),查詢字典中所有的值。

  • dict.items(),查詢字典中所有的鍵值對(duì)。

以上即為Python自帶的數(shù)據(jù)結(jié)構(gòu),共分為序列結(jié)構(gòu)和散列結(jié)構(gòu)兩大類,序列結(jié)構(gòu)有l(wèi)ist、tuple、string、unicode、buffer、xrange,散列結(jié)構(gòu)有set、dict。

關(guān)于Python中的數(shù)據(jù)結(jié)構(gòu)有哪些就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI