Python中的復(fù)雜數(shù)據(jù)類(lèi)型(list、tuple)
一、序列:
序列是基類(lèi)類(lèi)型,序列擴(kuò)展類(lèi)型包括:字符串、元組和列表

序列都可以進(jìn)行的操作包括索引,切片,加,乘,檢查成員。
此外,Python已經(jīng)內(nèi)置確定序列的長(zhǎng)度以及確定最大和最小的元素的方法。
二、列表(list):[a1,a2],可變數(shù)據(jù)類(lèi)型
列表:列表是序列類(lèi)型的一種擴(kuò)展,十分常用
1、列表的創(chuàng)建
- 列表是一種序列類(lèi)型,創(chuàng)建后可以隨意被修改
- 使用方括號(hào) [] 或list() 創(chuàng)建,元素間用逗號(hào) , 分隔
- 列表中各元素類(lèi)型可以不同,無(wú)長(zhǎng)度限制
hobby_list = [hobby, 'run', 'girl'] print(id(hobby_list)) # 4558605960 print(type(hobby_list)) # print(hobby_list) # ['read', 'run', 'girl']
如果想初始化個(gè)長(zhǎng)度為10的列表
list_empty = [None]*10 print(list_empty) # [None, None, None, None, None, None, None, None, None, None]
使用range()函數(shù)來(lái)創(chuàng)建一個(gè)列表:
hobby_list = list(range(5)) # [0, 1, 2, 3, 4]
2、復(fù)合列表和多維列表
hobby_list = ['read', 'run',['girl_name', 18, 'shanghai'] ] print(hobby_list[2][1])# 取出girl的年齡 18
python 創(chuàng)建二維列表,將需要的參數(shù)寫(xiě)入 cols 和 rows 即可
list_2d = [[0 for i in range(5)] for i in range(5)] list_2d[0].append(3) list_2d[0].append(5) list_2d[2].append(7) print(list_2d) # [[0, 0, 0, 0, 0, 3, 5], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 7], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]
以下實(shí)例將3X4的矩陣列表轉(zhuǎn)換為4X3列表:
# 以下實(shí)例展示了3X4的矩陣列表:
matrix = [
[1, 2, 3, 4],
[5, 6, 7, 8],
[9, 10, 11, 12],
]
# 以下實(shí)例將3X4的矩陣列表轉(zhuǎn)換為4X3列表:
transposed=[[row[i] for row in matrix] for i in range(4)]
print(transposed)
# [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
# 以下實(shí)例也可以使用以下方法來(lái)實(shí)現(xiàn):
transposed = []
for i in range(4):
transposed.append([row[i] for row in matrix])
print(transposed)
# [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]3、列表索引取值
索引序號(hào)從0開(kāi)始。
hobby_list = ['read', 'run', 'girl'] # 索引序號(hào) 0 1 2 print(hobby_list[1])# 取出第二個(gè)愛(ài)好 <code>run
4、列表修改
可以對(duì)列表的數(shù)據(jù)項(xiàng)進(jìn)行修改或更新,你也可以使用append()方法來(lái)添加列表項(xiàng),
hobby_list = ['read', 'run', 'girl'] hobby_list[0] = 'write'
列表方法使得列表可以很方便的作為一個(gè)堆棧來(lái)使用。堆棧作為特定的數(shù)據(jù)結(jié)構(gòu),最先進(jìn)入的元素最后一個(gè)被釋放(后進(jìn)先出)。
用 append() 方法可以把一個(gè)元素添加到堆棧頂。用不指定索引的 pop() 方法可以把一個(gè)元素從堆棧頂釋放出來(lái)。
- append:在列表ls最后增加一個(gè)元素x
- pop():移除列表中的一個(gè)元素(默認(rèn)最后一個(gè)元素),并且返回該元素的值
例如:
stack = [3, 4, 5] stack.append(6) stack.append(7) print(stack) # [3, 4, 5, 6, 7] print(stack.pop()) # 7 print(stack) # [3, 4, 5, 6] print(stack.pop()) # 6 print(stack.pop()) # 5 print(stack) # [3, 4]
三、列表推導(dǎo)式
列表推導(dǎo)式提供了從序列創(chuàng)建列表的簡(jiǎn)單途徑。通常應(yīng)用程序?qū)⒁恍┎僮鲬?yīng)用于某個(gè)序列的每個(gè)元素,用其獲得的結(jié)果作為生成新列表的元素,或者根據(jù)確定的判定條件創(chuàng)建子序列。
每個(gè)列表推導(dǎo)式都在 for 之后跟一個(gè)表達(dá)式,然后有零到多個(gè) for 或 if 子句。
返回結(jié)果是一個(gè)根據(jù)表達(dá)從其后的 for 和 if 上下文環(huán)境中生成出來(lái)的列表。如果希望表達(dá)式推導(dǎo)出一個(gè)元組,就必須使用括號(hào)。
1、列表推導(dǎo)式書(shū)寫(xiě)形式:
- [表達(dá)式 for 變量 in 列表]
- [表達(dá)式 for 變量 in 列表 if 條件]
舉例:
print([i for i in range(10)] ) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print([i ** 2 for i in range(10)]) # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
print([0 for i in range(5)]) #[0, 0, 0, 0, 0]
name_list = ['nick', 'sean', 'jason', 'tank']
for n in [name if name == 'nick' else name + '_a' for name in name_list] :
print(n) # 'nick', 'sean_a', 'jason_a', 'tank_a'
li = [1, 2, 3, 4, 5, 6, 7, 8, 9]
print( [x ** 2 for x in li]) # [1, 4, 9, 16, 25, 36, 49, 64, 81]
print( [x ** 2 for x in li if x > 5]) # [36, 49, 64, 81]
print(dict([(x, x * 10) for x in li])) # {1: 10, 2: 20, 3: 30, 4: 40, 5: 50, 6: 60, 7: 70, 8: 80, 9: 90} #生成字典
vec1 = [2, 4, 6]
vec2 = [4, 3, -9]
sq = [vec2[i] + vec2[i] for i in range(len(vec))] # 實(shí)現(xiàn)列表相加
print(sq)
# [6, 7, -3]
testList = [1, 2, 3, 4]
def mul2(x):
return x * 2
print([mul2(i) for i in testList]) #使用復(fù)雜表達(dá)式或嵌套函數(shù):
# [2, 4, 6, 8]2、列表推導(dǎo)式的嵌套
語(yǔ)句之間是嵌套關(guān)系。
左邊第二個(gè)語(yǔ)句是最外層,依次往右進(jìn)一層,左邊第一條語(yǔ)句是最后一層。
[x*y for x in range(1,5) if x > 2 for y in range(1,4) if y < 3]
他的執(zhí)行順序是:
for x in range(1,5)
if x > 2
for y in range(1,4)
if y < 3
x*y實(shí)例
print( [ (x, y) for x in range(10) if x % 2 if x > 3 for y in range(10) if y > 7 if y != 8]) #生成元組 # [(5, 9), (7, 9), (9, 9)] print([x * y for x in [1, 2, 3] for y in [1, 2, 3]]) # [1, 2, 3, 2, 4, 6, 3, 6, 9]
四、列表的基本操作
ls1 = ['python', 123]
ls2 = ['java', 456]
print(ls1 * 2); # ['python', 123, 'python', 123] 將列表復(fù)制n次。
print(ls1 + ls2); # ['python', 123, 'java', 456] 連接兩個(gè)列表
name_list = ['nick', 'jason', 'tank', 'sean']
del name_list[2] # 刪除索引2位置后的元素
print(name_list) # ['nick', 'jason', 'sean']
del name_list[2:4] # 從列表中刪除切片 ,刪除第i-j位置的元素
print(name_list) # ['nick', 'jason']
del name_list[:] #清空整個(gè)列表
print(name_list) # []
del a # 用 del 刪除實(shí)體變量:
name_list = ['nick', 'jason', 'tank', 'sean']
print('tank sb' in name_list) # 成員運(yùn)算:in; False
print('nick handsome' not in name_list) # 成員運(yùn)算:in;True
name_list = ['nick', 'jason', 'tank', 'sean']
for name in name_list: # for循環(huán)
print(name)
a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ']
for i in range(len(a)): # 結(jié)合range()和len()函數(shù)以遍歷一個(gè)序列的索引
print(i, a[i])
# 0 Google 1 Baidu 2 Runoob 3 Taobao 4 QQ
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list[0:3:2] ) # 切片 ['nick', 'tank']舉例:有如下列表,列表元素為不可hash類(lèi)型,去重,得到新列表,且新列表一定要保持列表原來(lái)的順序
stu_info_list = [
{'name': 'nick', 'age': 19, 'sex': 'male'},
{'name': 'egon', 'age': 18, 'sex': 'male'},
{'name': 'tank', 'age': 20, 'sex': 'female'},
{'name': 'tank', 'age': 20, 'sex': 'female'},
{'name': 'egon', 'age': 18, 'sex': 'male'},
]
new_stu_info_list = []
for stu_info in stu_info_list:
if stu_info not in new_stu_info_list:
new_stu_info_list.append(stu_info)
for new_stu_info in new_stu_info_list:
print(new_stu_info)五、列表相關(guān)函數(shù)
name_list = ['nick', 'jason', 'tank', 'sean']
print(len(name_list)) # 4 列表元素個(gè)數(shù):len;
print(min(name_list)) # jason 返回序列s的最小元素;
print(max(name_list)) # tank 返回序列s的最大元素
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.insert(1, 'handsome') # insert(i,x):在列表的第i位置增加元素x
print(name_list) # ['nick', 'handsome', 'jason', 'tank', 'sean']
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.remove('nick')) # remove(x):將列表ls中出現(xiàn)的第一個(gè)元素x刪除 ,None ;
print(name_list) # ['jason', 'tank', 'sean']
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.count('nick')) # 1 ;統(tǒng)計(jì)某個(gè)元素在列表中出現(xiàn)的次數(shù)
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.index('nick')) # 0;返回元素所在列表中的索引
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.clear() # 刪除列表中所有元素
print(name_list) # []
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.copy()) # 生成一個(gè)新列表,賦值原列表中所有元素 ['nick', 'jason', 'tank', 'sean']
name_list = ['nick', 'jason', 'tank', 'sean']
name_list2 = ['nick handsome']
name_list.extend(name_list2) # 在列表末尾一次性追加另一個(gè)序列中的多個(gè)值(用新列表擴(kuò)展原來(lái)的列表)
print(name_list) # ['nick', 'jason', 'tank', 'sean', 'nick handsome']
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.reverse() # 將列表ls中的元素反轉(zhuǎn)
print(name_list) # ['sean', 'tank', 'jason', 'nick']
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.sort() # 排序,使用用sort列表的元素必須是同類(lèi)型的
print(name_list) # ['jason', 'nick', 'sean', 'tank']
name_list.sort(reverse=True) # 倒序
print(name_list) # ['tank', 'sean', 'nick', 'jason']六、元組(tuple):(a1,a2)
1、元組的創(chuàng)建
元組是一種列表類(lèi)型,一旦創(chuàng)建就不能被修改。
color = (0x001100, "blue", creature) # 使用小括號(hào) () 或 tuple() 創(chuàng)建,元素間用逗號(hào)分隔。 print(type(color)) # creature = "cat", "dog", "tiger", "human" # 可以使用或不使用小括號(hào)。即元組由若干逗號(hào)分隔的值組成。 print(type(creature)) #
注意與字符串區(qū)別:
name_str = ('egon') # ()只是普通包含的意思
name_tuple = ('egon',) # 元組中只包含一個(gè)元素時(shí),需要在元素后面添加逗號(hào),否則括號(hào)會(huì)被當(dāng)作字符串使用:
print(type(name_str)) #
print(type(name_tuple)) #2、元組的操作
索引取值、切片(顧頭不顧尾,步長(zhǎng))、長(zhǎng)度len、成員運(yùn)算in和not in、循環(huán)、count、index等均同列表,只是不更改值。
元組中的元素值是不允許修改的,但我們可以對(duì)元組進(jìn)行連接組合,如下實(shí)例:
tup1 = (12, 34.56);
tup2 = ('abc', 'xyz')
# 以下修改元組元素操作是非法的。
# tup1[0] = 100
# 創(chuàng)建一個(gè)新的元組
tup3 = tup1 + tup2;
print(tup3) # (12, 34.56, 'abc', 'xyz')3、namedtuple(具名元組): Python元組的升級(jí)版本
from collections import namedtuple
User = namedtuple('User', 'name sex age') # 定義一個(gè)namedtuple類(lèi)型User,并包含name,sex和age屬性。
user = User(name='Runoob', sex='male', age=12) # 創(chuàng)建一個(gè)User對(duì)象
print(user.age) # 12到此這篇關(guān)于Python中的復(fù)雜數(shù)據(jù)類(lèi)型(list、tuple)的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
將pycharm配置為matlab或者spyder的用法說(shuō)明
這篇文章主要介紹了將pycharm配置為matlab或者spyder的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06
Python3.8 + Tkinter: Button設(shè)置image屬性不顯示的問(wèn)題及解決方法
這篇文章主要介紹了Python3.8 + Tkinter: Button設(shè)置image屬性不顯示的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08
python3+PyQt5 創(chuàng)建多線(xiàn)程網(wǎng)絡(luò)應(yīng)用-TCP客戶(hù)端和TCP服務(wù)器實(shí)例
今天小編就為大家分享一篇python3+PyQt5 創(chuàng)建多線(xiàn)程網(wǎng)絡(luò)應(yīng)用-TCP客戶(hù)端和TCP服務(wù)器實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
Python實(shí)現(xiàn)迪杰斯特拉算法過(guò)程解析
這篇文章主要介紹了Python實(shí)現(xiàn)迪杰斯特拉算法過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
Python類(lèi)的基本寫(xiě)法與注釋風(fēng)格介紹
這篇文章主要介紹了Python類(lèi)的基本寫(xiě)法與注釋風(fēng)格,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
python?DataFrame中l(wèi)oc與iloc取數(shù)據(jù)的基本方法實(shí)例
這篇文章主要給大家介紹了關(guān)于python?DataFrame中l(wèi)oc與iloc取數(shù)據(jù)的基本方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02
Python實(shí)現(xiàn)輕松找出兩個(gè)列表不同之處
在日常編程中,需要比較兩個(gè)列表并找出它們之間差異是一種常見(jiàn)需求,在本文中,我們將深入探討Python中查找兩個(gè)列表差異值的方法,需要的小伙伴可以參考下2023-12-12

