當前位置:首頁 » 編程語言 » python列表的使用

python列表的使用

發布時間: 2023-03-12 06:58:54

『壹』 四、 python中的數據類型——列表

列表是一種有序的集合,有點類似c裡面的數組。它的特點是,可以隨時向裡面添加或刪除其中的元素,在python中經常用來存放數據。列表的特點是中括弧,內部元素用逗號隔開。

在這個列表中,可以放進去任何元素,不論你的元素是字元串、整型、浮點型、還是布爾值、空值,包括列表什麼的,都可以放進去。
元素與元素之間,用逗號隔開。

列表會為每個元素分配序號,這個序號代表它的位置,稱為索引(index),第一個元素的位置是0,第二個元素是1,以此類推。

使用索引獲取列表中的值時,需要使用中括弧來訪問,在中括弧前面加上列表名,中括弧內部是元素的索引。
0代表第一個元素的位置,1代表第二個,-1代表倒數第一個,-2代表倒數第二個

使用 len() 函數,可以查看列表裡面有多少個元素

在python中,列表的操作是非常的靈活的,我們可以向其中添加或刪除元素。
添加使用 list.append() 函數

list.append() 函數是將元素插入到列表的末尾,當我們想在特定位置插入元素時可以使用 list.insert() 函數

list.insert() 函數接受兩個參數,第一個參數是插入位置,第二個參數是要插入的元素。

需要注意的是,在使用append和insert時,必須在前面註明要操作的列表。就像上面的例子,我們要操作classmates這個列表,所以必須寫成 classmates.append() 或 classmates.insert() ,如果不這么寫,計算機就不知道你要往哪個列表中加入元素。

沒有特殊情況的話,推薦使用append()函數添加元素,因為使用append的時候,元素默認加在列表尾部,不會造成其他元素索引值的改變。如果使用insert的話,就像上面的insert(1,'Tom'),在位置1插入'Tom'後,Tom後面所有的元素,索引值都加了一個1,列表中元素越多,受影響的程度越大,因此使用append()函數要比insert()函數更快。

刪除列表中元素的方法有三種

del後面需要用索引的方式表明要刪除的元素,也就是上面的例子,names[1]代表names中的第二個元素,使用del即可刪除

list.pop() 函數與del差不多,都是使用索引值進行刪除,只不過寫法不同。
我們可以發現,執行 names.pop(1) 後,python shell列印出了第二個元素的值,也就是我們要刪除的那個值,這是因為 pop() 這個函數,是有返回值的,有時候我們需要使用這個值,這個時候就可以用變數存起來。

這樣我們就可以通過調用a而使用剛才刪掉的元素了。

list.remove() 函數的作用是刪除第一個匹配的元素,上面的例子中,names這個列表裡面,有兩個'Bob',remove函數只刪除了第一個'Bob'。這就是 list.remove() 函數的特點。

有時候我們想使用列表的前10個元素,或者前n個元素,這時候就應該使用列表的切片。

切片和索引類似,都是使用中括弧,區別是,索引中的中括弧裡面只有一個數,而切片不同。切片是切割列表,形成切割下來的部分形成新的列表。

切片: list[start:end:[step=1]] ,這就是切片的表達式,要求start和end兩者必須有一個,step不是可以不指定,不指定的時候默認為1。

切片該怎麼理解呢,start就是開始的位置,end就是結束的位置。切片有個特點是「取前不取後」,看上面那個例子可以發現,1作為start,3作為end,1代表第二個元素,3代表第四個元素,列表切片的時候,是不取後面的那個數字對應的元素的,也就是不取第四個元素,所以names[1:3]只取了第二個元素和第三個元素,這就是所謂的取前不取後。

再看下一個例子。

當不指定start或者end的時候,start默認為0,end默認為最後一個元素的索引值+1,因為「取前不取後」,要想取到最後一個元素,必須加個1才行。
上例中,用 len(numbers) 表示了最後一個元素的索引值,因為索引值從0開始,最後一個元素的索引值一定是列表內元素個數-1,根據「取前不取後」,在end位置上的數字應該+1,所以最後就等於 len(numbers) 了。
當不設定start和end的時候,就默認取所有的元素了。

當加入step,這個選項後,step代表步長,默認為1,設定成2的時候,就是隔一個取一個,設定成3時就是隔兩個取一個。
上例中,第一個切片,start和end均未設定,因此從第一個元素開始,隔一個取一個,得到了所有奇數位置的元素。
第二個切片,start設定為了1,因此取了所有偶數位置的元素。

3在列表中,0不在列表中,所以 3 in a 是True,而 0 in a 是False

更多關於列表的信息可以通過使用 help(list) 查看幫助文檔。

『貳』 Python中的列表

列表(list)是Python中一個非常重要的類型,用於管理一組數據,列表的形式如下所示
country = ['China', 'Germany', 'Russia', 'America']

1)數據包含在引號中,Python中單引號和雙引號具有相同的作用
2)使用逗號分隔數據,整個列表包含在一個中括弧中
3)適用賦值操作符將一個列表賦值給一個變數名如上述例子中的「country」, Python的變數名不需要聲明類型

country = []

列表不僅可以存放字元串這樣的數據,還可以存放混合類型的數據,例如在列表中存儲列表

除了列表外還可以存儲字典和元組,字典和元組另作介紹

列表可以像數組那樣通過下標獲取列表中的數據,數據類型---字元串

列表可以適用冒號「:」操作符選取列表中的一部分數據,選取出的數據成為切片,實際上是字列表,但這些數據需要是連續的。
此外數據可以正向取如示例中的「0 : 2」得到列表['China', 'Germany'], 也可以反向取如「-2:-1」
需要注意的是即使切片只取一個數據得到的也是一個列表,而不是一個字元串,與使用索引得到的數據是不同的

添加數據可以使用 insert() 和 append() 兩種方法,如下所示:

insert() 第一個參數確定插入的位置,在這個位置之後插入需要插入的數據, append() 將數據添加到列表的尾部

從列表中找出某個值第一個匹配項的索引位置

只能查找第一層數據,如果差列表中的列表,需要將列表全部輸入。函數中的start和stop用於確定搜索范圍

移除列表中的一個元素(默認最後一個元素),並且返回該元素的值

移除列表中某個值的第一個匹配項

反向列表中元素

對原列表進行排序

『叄』 python列表的基本操作

python列表的基本操作如下:

01'''

02列表:有非常重要的地位。(list)

03[項,項...]

04'''

05list1=['zhang san','li si','wang wu']

06print(list1)

07 #直接創建列表

08 list0=[]#空列表

09 print(type(list0))#類型

10 list2=[1,2,3,4,5]#數值型列表

11 list3=['張三',14,'8年級','34班']

12 print(list2)

13 print(list3)

14 lista=list(range(10))#range()不包括結束數值

15print(lista)

16listb=list(range(0,11,2))

列表的特點:

列表是一個有序序列,列表可以包含任意類型的對象。列表是可變的。可以添加、刪除和賦值。列表存儲的是對象的引用。每個列表成員存儲的是對象的引用,而不是對象本身。列表是可變序列,通常用於存放同類項目的集合。

『肆』 Python列表的常用操作- 查找方法【詳細講解】

列表的作用是一次性存儲多個數據,程序員可以對這些數據進行的操作有:增、刪、改、查。

下面講解的是對列表的查找操作,可以分為兩種方法,一種是根據下標來進行查找,另外一種是根據查找函數來操作。

回憶一下知識點,之前講過字元串的時候有說到下標,下標是計算機內存分配的從0開始的編號,目的是根據下標可以找到針對性的數據。列表也可以根據下標來找到數據,後面學習的元組同樣也可以。

語法:

注意:如果以後都是用下標來查找數據,語法無非就是:序列名[下標]

快速體驗:

列印結果如圖:

語法:

快速體驗:

執行結果如圖:

注意:

語法:

快速體驗:

注意

-- 2. 如果書寫了開始和結束位置的下標,則在這個范圍內查找,存在則返回開始位置的下標,如果查找的數據不存在則返回0;

語法:

注意: len()方法是一個公共的方法,無論是字元串、列表還是元組都可以使用

快速體驗:

以上就是列表的4種查找方法,每個方法有自己的語法和作用,這個知識點屬於 Python基礎教程 范疇,所以學起來還是比較輕松地,大家主要多多練習記住函數以及使用方法即可。

『伍』 python 列表切片的用法集合

"""
其中,第一個數字start表示切片開始位置,默認為0;
第二個數字end表示切片截止(但不包含)位置(默認為列表長度);
第三個數字step表示切片的步長(默認為1)。
當start為0時可以省略,當end為列表長度時可以省略,
當step為1時可以省略,並且省略步長時可以同時省略最後一個冒號。
另外,當step為負整數時,表示反向切片,這時start應該比end的值要大才行。
"""
aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
print (aList[::]) # 返回包含原列表中所有元素的新列表
print (aList[::-1]) # 返回包含原列表中所有元素的逆序列表
print (aList[::2]) # 隔一個取一個,獲取偶數位置的元素
print (aList[1::2]) # 隔一個取一個,獲取奇數位置的元素
print (aList[3:6]) # 指定切片的開始和結束位置
aList[0:100] # 切片結束位置大於列表長度時,從列表尾部截斷
aList[100:] # 切片開始位置大於列表長度時,返回空列表

aList[len(aList):] = [9] # 在列表尾部增加元素
aList[:0] = [1, 2] # 在列表頭部插入元素
aList[3:3] = [4] # 在列表中間位置插入元素
aList[:3] = [1, 2] # 替換列表元素,等號兩邊的列表長度相等
aList[3:] = [4, 5, 6] # 等號兩邊的列表長度也可以不相等
aList[::2] = [0] * 3 # 隔一個修改一個
print (aList)
aList[::2] = ['a', 'b', 'c'] # 隔一個修改一個
aList[::2] = [1,2] # 左側切片不連續,等號兩邊列表長度必須相等
aList[:3] = [] # 刪除列表中前3個元素

del aList[:3] # 切片元素連續
del aList[::2] # 切片元素不連續,隔一個刪一個

『陸』 Python其實很簡單 第九章 列表與元組(一)

在前面,我們要保存一個數據,需要先定義一個變數,而且一個變數中只能保存一個數據。譬如,語句:a1=1,值「1」就被保存了,但要保存「2」,就還需要再定義一個變數:a2=2......這樣以來,隨著數據的增多,豈不是要定義更多的變數嗎?

可以使用一個新的數據類型,它記錄很多數據,並且將它們按照順序存儲在連續的內存空間中,這便是序列。Python中有5種常用的序列結構,分別是列表、元組、集合、字典和字元串。

9.1列表

語法格式:

listname=[element1,element2,element3,......,elementn]

其中,listname為列表名,element1,element2,element3,......,elementn表示列表中的元素。各個元素的數據類型可以相同,也可以不同,但通常元素的類型都是相同的,含義也是相同的。

如:

list1=[『風』,』馬『,』牛』,1,2,3,』a』,』b』,』c』]就沒有太多的實際用途。

list2=['張三','男',18,�']雖然元素的類型不同,但表示了同一個人的信息。

1、訪問列表元素

列表中元素的索引號從0開始標記,訪問列表元素時,可以直接按照索引號讀取。

如:

list2=['張三','男',18,�']

print(list2[1]) #輸出列表中索引號為1的元素

輸出結果:男

和字元串一樣,序列都是可以使用切片操作的。

如:

print(list2[:2])

輸出結果:['張三', '男']

print(list2[2:])

輸出結果:[18, �']

2、使用range()函數創建數值列表

格式:range(start, stop [,step]) ;start 指的是計數起始值,默認是 0;stop 指的是計數結束值,但不包括 stop ;step 是步長,默認為 1,不可以為 0 。range() 方法生成一段左閉右開的整數范圍。

可以使用range()函數創建數值列表,如:

list1=list(range(10,20,2))

print(list1)

運行結果:[10, 12, 14, 16, 18]

3、刪除列表

語法格式如下:

del listname

其中,listname為要刪除列表的名稱。

刪除列表與刪除變數的方法是完全一樣的,前面已經介紹過了。

4、遍歷列表

常用的遍歷列表的方法有是利用for語句,舉例如下:

list1=list(range(10))

for item in list1:

print(item,end=' ') # end=』 『表示以空格結束,如果不寫這個參數,相當於默認值end=』 』

輸出結果:0 1 2 3 4 5 6 7 8 9

為了獲取列表元素的索引值,就需要使用enumerate()函數。

list1=list(range(10,20,2))

for index,item in enumerate(list1):

print(index,'-',item,end=' ')

輸出結果:0 - 10 1 - 12 2 - 14 3 - 16 4 - 18

5、追加、修改和刪除列表元素

追加元素

>>> list1=['春','夏','秋']

>>> list1.append('冬')

>>> list1

['春', '夏', '秋', '冬']

還有一種方法,就是使用「+」號將兩個序列連接起來。如:

list1=['春','夏','秋']

list1=list1+['冬']

print(list1)

輸出結果為:['春', '夏', '秋', '冬']

注意,下面的做法是錯誤的:

>>> list1=['春','夏','秋']

>>> list1=list1+'冬'

Traceback (most recent call last):

File " ", line 1, in

list1=list1+'冬'

TypeError: can only concatenate list (not "str") to list

從這個提示可知,列表只能與列表連接,而不能與字元串連接。

修改元素

>>> list1[2]='autumn' #通過索引對元素直接賦值

>>> print(list1)

['春', '夏', 'autumn', '冬']

刪除元素

>>> del list1[2] #通過索引直接刪除元素

>>> print(list1)

['春', '夏', '冬']

6、列表元素排序

在討論列表元素排序時,為了將有序列表變成無序列表,這里用到了shuffle()函數,但它不是Python的內置函數,需要先使用import語句將random模塊包含進來,這樣才能像使用內置函數那樣使用擴展模塊中的函數。

>>> import random #導入random模塊

>>> list1=list(range(10)) #生成列表,元素為0到9的整數。

>>> list1

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

>>> random.shuffle(list1) #用random包中的shuffle()函數將list1中元素次序打亂

>>> list1

[8, 6, 3, 5, 0, 7, 1, 9, 2, 4]

>>> list1.sort() #對list1升序排列

>>> list1

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

>>> random.shuffle(list1) #將list1順序重新打亂

>>> list1

[5, 9, 7, 8, 4, 3, 2, 0, 6, 1]

>>> list1.sort(reverse=True) #對list1降序排列

>>> list1

[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]

方法sort()的語法格式:

listname.sort(key=None,reverse=False)

其中,listname表示要排序的列表;key表示指定一個鍵,如」key=str.lower」表示排序時不區分字母大小寫;reverse為True表示降序排列(為默認值,可省缺),為False表示升序排列。

還有一個函數sorted(),功能與方法sort()相似。格式如下:

sorted(listname,key=None,reverse=False)

7、 利用列表推導式快速生成一個列表

例1:生成指定范圍的數值列表。

>>> import random

>>> list1=[random.randint(0,20) for i in range(10)]

>>> list1

[16, 20, 19, 6, 5, 7, 10, 5, 12, 5] #生成了包含10個值在0到20之間的元素構成的列表。

例2:根據現有列表生成新的列表。

>>> radius=list(range(1,6)) #生成列表 radius保存半徑的值

>>> radius

[1, 2, 3, 4, 5]

>>> s=[round(2*3.14*r,2) for r in radius]

#生成列表s,將計算得到的周長值保存起來,其中round()可以保留指定小數位,格式 round(var, n),var為變數名,n為指定保留小數位。

>>> s

[6.28, 12.56, 18.84, 25.12, 31.4]

例3:從列表中選擇符合條件的元素組成新的列表。

>>> score=[98,65,77,56,82,89] #列表score用來存儲成績

>>> good=[x for x in score if x>=80]

#從列表score中選取>=80的元素存入新列表good中

>>> good

[98, 82, 89]

count()、index()和sum()方法

count()方法

用於統計指定元素在列表中出現的次數。

例:

>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']

>>> num=list1.count('c') #統計列表list1中'c'的個數

>>> num

3

index()方法

用於獲取指定元素在列表中第一次出現的索引值。

>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']

>>> position=list1.index('c')

>>> position

2

sum()方法

用於計算數值列表中全部或指定元素的和。

>>> list1=[1,2,3,4,5]

>>> total=sum(list1) #計算列表list1中全部元素的和

>>> total

15

>>> total=sum(list1,1) #在列表list1全部元素的和後,在加上參數(「1」)的值

>>> total

16

>>> total=sum(list1[:2]) #計算切片list1[:2]中各元素的和

>>> total

3

二維列表

格式:listname[下標1][下標2]

其中,listname表示列表的名稱,下標1表示列表中的行號,下標2表示列表中的列號。對於n行m列的二維列表,第一個元素的行號和列號都是0,最後一個元素的行號和列號都是n-1。如下所示:

list[0][0] list[0][1] list[0][2] ............ list[0][m-1]

list[1][0] list[1][1] list[1][2] ............ list[1][m-1]

......

......

list[n-1][0] list[n-1][1] list[n-1][2] ............ list[n-1][m-1]

通俗地講,如果一個列表中的元素本身就是一個列表,則這個列表就是一個二維列表。

如:

>>> list1=['a1','b1','c1','d1']

>>> list2=['a2','b2','c2','d2']

>>> list3=['a3','b3','c3','d3']

>>> listtwo=[list1,list2,list3]

>>> listtwo

[['a1', 'b1', 'c1', 'd1'], ['a2', 'b2', 'c2', 'd2'], ['a3', 'b3', 'c3', 'd3']]

如果要查看二維列表listtwo按照行、列的排列,可以運行如下代碼:

for i in range(3):

for j in range(4):

print(listtwo[i][j],end=' ')

print()

運行結果:

a1 b1 c1 d1

a2 b2 c2 d2

a3 b3 c3 d3

如果要讀取二維列表中的某一行,可以使用如下方法:

>>> listtwo[2] #讀取第3行的元素(注意索引號都是從0開始的)

['a3', 'b3', 'c3', 'd3']

如果要讀取某一個元素的值,可以使用如下方法:

>>> listtwo[2][2] #讀取第3行第3列的元素

'c3'

『柒』 python列表的基本操作

列表是一個有序且可更改的集合。在 Python 中,列表用方括弧編寫。

List是python中的一種數據類型,它由一組有序的元素組成。支持字元、數字、字元串甚至也可以包含列表(列表中有列表,嵌套),元素間用逗號進行分隔。

列表用[]進行標識。

列表的定義:

(1)定義一個空列表:

list_stu1 = []。

list_stu2 = list()。

(2)定義一個有學生信息的列表:

list_stu1 = ['張三',19,'男','長沙',13434343434] #使用一個列表存一個學生的基本信息 。

print(list_stu1) 。

list_stu2 = [['張三',19,'男','長沙',13434343434], #通過列表嵌套存多個學生的信息 。

['李四',18,'男','武漢',13535353535]。

['王五',22,'女','上海',13636363636]] 。

print(list_stu2)。

[『張三』, 19, 『男』, 『長沙』, 13434343434]。

[[『張三』, 19, 『男』, 『長沙』, 13434343434], [『李四』, 18, 『男』, 『武漢』, 13535353535], [『王五』, 22, 『女』, 『上海』, 13636363636]]。



『捌』 python中的列表中常用的方法有哪些,分別是什麼作用

Python列表定義:按特定順序排列的元素組成。在Python中,用方括弧[]來表示列表,並用逗號來分隔其中的元素。Python列表是編程中很常見的數據類型 。
列表是一種可修改的集合類型,其元素可以是數字、string等基本類型,也可以是列表、元組、字典等集合對象,甚至可以是自定義的類型。其定義方式如下:>>> nums = [1,2,3,4]>>> type(nums)>>> print nums[1, 2, 3, 4]>>> strs = ["hello","world"]>>> print strs['hello', 'world']>>> lst = [1,"hello",False,nums,strs]>>> type(lst)>>> print lst[1, 'hello', False, [1, 2, 3, 4], ['hello', 'world']]
下面我們來看一下列表中有哪些常見的方法:count():統計某個元素在列表中出現的次數。index():從列表中找出某個值第一個匹配項的索引位置。append():在列表末尾添加新對象。extend():在列表末尾一次性追加另一個序列的多個值。insert():在列表的指定位置插入對象。pop():移除列表中的一個元素(默認最後一個元素),並且返回該元素的值。remove():移除列表中某個值的第一個匹配項。reverse():將列表中的元素反向,不重新拷貝一個列表。reversed():將列表中的元素反向,重新拷貝一個列表。sort():將列表中的元素排序,不重新拷貝一個列表。sortd():將列表中的元素排序,重新拷貝一個列表。():淺拷貝,只是給原來的列表貼上了一個新標簽,對於一個復雜對象的子對象並不會完全復制,如果有子列表,改變原來的值,新的拷貝對象也會改變。deep():深拷貝,將復雜對象的每一層復制一個單獨的個體出來。就是完全拷貝。常見內置函數:max()、min()、sum()、len()、all()、any()、zip()、enumerate()

熱點內容
動態規劃01背包演算法 發布:2024-11-05 22:17:40 瀏覽:849
nasm編譯器如何安裝 發布:2024-11-05 22:01:13 瀏覽:181
登錄密碼在微信的哪裡 發布:2024-11-05 22:00:29 瀏覽:739
c防止反編譯工具 發布:2024-11-05 21:56:14 瀏覽:248
安卓虛擬機怎麼用 發布:2024-11-05 21:52:48 瀏覽:344
php時間搜索 發布:2024-11-05 20:58:36 瀏覽:479
燕山大學編譯原理期末考試題 發布:2024-11-05 20:13:54 瀏覽:528
華為電腦出現臨時伺服器 發布:2024-11-05 20:05:08 瀏覽:408
斗戰神免費挖礦腳本 發布:2024-11-05 19:53:25 瀏覽:665
網吧伺服器分別是什麼 發布:2024-11-05 19:45:32 瀏覽:392