列表list是python基本的數(shù)據(jù)結(jié)構(gòu),是可變序列应闯,允許有重復(fù)元素护侮。
環(huán)境
- win10 64bit
- python 3.9
創(chuàng)建
列表的創(chuàng)建可以通過(guò)內(nèi)置的list
類創(chuàng)建,也可以用方括號(hào)[]
創(chuàng)建吃挑,列表中的元素可以是任意數(shù)據(jù)類型钝荡,列表可嵌套列表。
list
通過(guò)list
類創(chuàng)建列表實(shí)例舶衬,傳入的參數(shù)必須是可迭代對(duì)象
埠通。常見(jiàn)的數(shù)據(jù)類型tuple
,list
,set
,dict
,str
等都是可迭代對(duì)象。
# 元組創(chuàng)建列表
list((1,2,3))
# 集合創(chuàng)建列表
list({1,2,3})
[1, 2, 3]
通過(guò)字典創(chuàng)建列表時(shí)逛犹,只有字典的key會(huì)轉(zhuǎn)為列表端辱。
# 字典創(chuàng)建列表
list({'a':1,'b':2})
['a', 'b']
# 字符串創(chuàng)建列表
list('abc')
['a', 'b', 'c']
# 空列表
list()
[]
空列表取布爾值,返回False
虽画。
bool(list())
False
[]
用方括號(hào)[]
包裹對(duì)象舞蔽,并用,
分割,可創(chuàng)建列表码撰。
# []創(chuàng)建列表
[1,2,'a',True]
[1, 2, 'a', True]
# 嵌套列表
[1,2,[3,4,['a',True]]]
[1, 2, [3, 4, ['a', True]]]
# 空列表
[]
[]
計(jì)數(shù)
count
count
方法計(jì)算列表中某一個(gè)元素出現(xiàn)的次數(shù)渗柿。
# 列表元素計(jì)數(shù)
[1,2,1].count(1)
2
len
__len__()
方法計(jì)算列表的總長(zhǎng)度。
[1,2,1].__len__()
3
查詢
[]
方括號(hào)[]
除了可以構(gòu)造列表外脖岛,還可以通過(guò)索引查詢列表中的元素朵栖。可傳入整數(shù)或切片進(jìn)行查詢柴梆。
l=['a','b','c','d','e']
# 整數(shù)查詢單個(gè)元素
l[0]
'a'
# 切片查詢多個(gè)元素
l[1:3]
['b', 'c']
# 切片反向查詢多個(gè)元素
l[-3:]
['c', 'd', 'e']
通過(guò)[]
方法索引目標(biāo)元素陨溅,并賦值,可以修改列表中的元素绍在。
l=['a','b','c']
l[0]='A'
l
['A', 'b', 'c']
index
index
方法查詢?cè)氐谝淮纬霈F(xiàn)的索引位置门扇”⒂校可設(shè)置查找的起止范圍。
l=['b','a','b','c']
# 查詢?cè)氐谝淮纬霈F(xiàn)的索引位置
l.index('b')
0
# 查詢?cè)氐谝淮纬霈F(xiàn)的索引位置(指定索引1到4查找)
l.index('b',1,3)
2
插入
在列表中插入值有append
,extend
,insert
三種方法悯嗓,三種方法均返回None
件舵,會(huì)修改列表卸察。
append
append
方法在列表末尾插入一個(gè)新元素脯厨。
# 末尾插入新元素
l=[1,2,3]
l.append(4)
l
[1, 2, 3, 4]
insert
insert
方法在列表指定位置插入一個(gè)新元素。
# 在索引1的位置插入一個(gè)元素
l=[1,2,3]
l.insert(1,11)
l
[1, 11, 2, 3]
extend
extend
方法在列表末尾插入一個(gè)可迭代對(duì)象坑质,可迭代對(duì)象可以是list
,tuple
等數(shù)據(jù)類型合武。
# 末尾插入可迭代對(duì)象
l=[1,2,3]
l.extend((4,5,6))
l
[1, 2, 3, 4, 5, 6]
刪除
刪除列表中的元素有clear
,pop
,remove
三種方法,用關(guān)鍵字del
刪除整個(gè)列表涡扼。
clear
clear
方法刪除列表中的所有元素稼跳,返回None
,列表變成空列表吃沪。
l=[1,2,3]
l.clear()
l
[]
pop
pop
方法根據(jù)索引刪除列表中的元素汤善,并返回刪除的元素。默認(rèn)從最后一個(gè)位置開(kāi)始刪除票彪。
# 刪除最后一個(gè)位置元素
l=[1,2,3]
e=l.pop()
print(f'刪除后列表:{l}红淡,刪除的元素:{e}')
刪除后列表:[1, 2],刪除的元素:3
# 刪除索引為2的元素
l=[1,2,3]
e=l.pop(1)
print(f'刪除后列表:{l}降铸,刪除的元素:{e}')
刪除后列表:[1, 3]在旱,刪除的元素:2
remove
remove
方法刪除第一次出現(xiàn)的元素,返回None
推掸,會(huì)修改列表桶蝎。
# 刪除第一次出現(xiàn)的元素
l=['b','a','c','a']
l.remove('a')
l
['b', 'c', 'a']
del
del
會(huì)刪除整個(gè)列表,從當(dāng)前命名空間中移除谅畅。
l=[1,2,3]
del l
重復(fù)
copy
copy
方法復(fù)制一個(gè)完全相同的列表登渣。
l=[1,2,3]
ll=l.copy()
ll
[1, 2, 3]
*
乘號(hào)*
用于重復(fù)多個(gè)列表。
l=[1,2,3]
l*3
[1, 2, 3, 1, 2, 3, 1, 2, 3]
反轉(zhuǎn)
reverse
方法反轉(zhuǎn)列表毡泻,返回None
胜茧,會(huì)修改列表。
l=[1,2,3]
l.reverse()
l
[3, 2, 1]
排序
sort
方法對(duì)列表進(jìn)行排序牙捉,返回None
竹揍,會(huì)修改列表。默認(rèn)升序排序邪铲,設(shè)置reverse=True
為降序排序芬位。
# 升序排序
l=[1,8,2,6,3]
l.sort()
l
[1, 2, 3, 6, 8]
# 降序排序
l=[1,8,2,6,3]
l.sort(reverse=True)
l
[8, 6, 3, 2, 1]
設(shè)置key
參數(shù),可以對(duì)元素是可迭代對(duì)象的列表進(jìn)行排序带到,
key
參數(shù)設(shè)置為函數(shù)昧碉,指定根據(jù)可迭代對(duì)象的哪個(gè)元素進(jìn)行列表排序。
# 根據(jù)元組的第一個(gè)元素升序排序
l=[(2,4),(5,1),(1,8)]
l.sort(key=lambda t:t[0])
l
[(1, 8), (2, 4), (5, 1)]
合并
符號(hào)+
可以合并列表。
# 合并列表
l1=[1,2,3]
l2=[4,5,6]
l1+l2
[1, 2, 3, 4, 5, 6]
結(jié)合reduce
函數(shù)被饿,可以批量合并多個(gè)列表四康。
# 批量合并多個(gè)列表
from functools import reduce
l=[[1,2],[3,4],[5,6]]
list(reduce(lambda x,y:x+y,l))
[1, 2, 3, 4, 5, 6]
推導(dǎo)式
推導(dǎo)式comprehensions是python的一種獨(dú)有特性,可以從一個(gè)數(shù)據(jù)序列構(gòu)建新的數(shù)據(jù)序列狭握。
列表推導(dǎo)式的主要形式有:[exp for x in data if condition]
闪金,[exp1 if condition else exp2 for x in data]
。
通過(guò)列表推導(dǎo)式论颅,可以很方便的篩選哎垦、修改列表。
# if條件篩選列表
l=[1,2,3,7,1]
[x for x in l if x>1]
[2, 3, 7]
# if-else條件篩選列表
l=[1,2,3,7,1]
[x if x>1 else 0 for x in l]
[0, 2, 3, 7, 0]
多層for
循環(huán)也可以在列表推導(dǎo)式中使用恃疯。一般不超過(guò)2層漏设,否則可讀性會(huì)大大降低。
l=[[1,2],[3,4],[3,7]]
# 篩選第一個(gè)元素是3的嵌套列表
[x for x in l for i in x if i==3]
[[3, 4], [3, 7]]
扁平化
有時(shí)候需要對(duì)嵌套列表進(jìn)行扁平化操作今妄,即多層嵌套列表展開(kāi)到一層郑口。可以通過(guò)列表推導(dǎo)式和遞歸函數(shù)完成盾鳞。
# 定義列表扁平化函數(shù)
def flat_list(obj):
return [i for g in obj for i in flat_list(g)] if isinstance(obj, list) else [obj]
# 嵌套列表
l=[[1,2,3],4,[5,[6,[7]]]]
# 扁平化嵌套列表
flat_list(l)
[1, 2, 3, 4, 5, 6, 7]