Python列表介紹
- 2020 年 1 月 1 日
- 筆記
本文標識 : Python_4
本文編輯 : Jack 風
編程工具 : Anaconda、Pycharm
閱讀時長 : 10分鐘
1、列表介紹
字符串用來存儲一串信息,怎樣存儲公號所有粉絲的名字呢? 那麼定義10個變量,每個變量存放一個粉絲的姓名可行嗎?有無更好方式?
答:
列表
1.1、列表的格式
變量namelist的類型為列表
namesList = ['a2data','a2data1','a2data2']
與C語言的數組相比的話,強大的地方在於列表中的元素可以是不同類型的
testList = [1, 'a']
1.2、打印列表
demo:
namesList = ['a2data','a2data1','a2data2'] print(namesList[0]) print(namesList[1]) print(namesList[2])
結果:
a2data a2data1 a2data2
2、列表的循環
2.1、 使用for循環
高效輸出列表的每個數據,使用循環即可
demo:
namesList = ['a2data','a2data1','a2data2'] for name in namesList: print(name)
結果:
a2data a2data1 a2data
2.2、 使用while循環
demo:
namesList = ['a2data','a2data1','a2data2'] length = len(namesList) i = 0 while i<length: print(namesList[i]) i+=1
結果:
a2data a2data1 a2data2
3、列表的常見操作
列表中數據修改方式,比如大家常見的 "增"、"刪"、"改"、"查"
3.1、添加元素
append
append方式向列表添加元素
demo:
#變量AAA,有3個元素 AAA = ['a2data','a2data1','a2data2'] print("-----AAA的數據為-----") for tempName in AAA: print(tempName) #提示、並添加元素 temp = input('請輸入要添加的name:') AAA.append(temp) print("-----添加之後,列表AAA的數據-----") for tempName in AAA: print(tempName)
extend
extend可以將另一個集合中的元素逐一添加到列表中
>>> a = [1, 2] >>> b = [3, 4] >>> a.append(b) >>> a [1, 2, [3, 4]] >>> a.extend(b) >>> a [1, 2, [3, 4], 3, 4]
insert
insert(index, object) 在指定位置index前插入元素object
>>> a = [0, 1, 2] >>> a.insert(1, 3) >>> a [0, 3, 1, 2]
3.2、修改元素
("改"):修改元素的時候,要通過下標來確定要修改的是哪個元素,然後才能進行修改
demo:
ABC = ['a2data','a2data1','a2data2'] print("-----修改之前,列表ABC 的數據-----") for tempName in ABC: print(tempName) #修改元素 ABC[1] = 'a2data666' print("-----修改之後,列表ABC的數據-----") for tempName in A: print(tempName)
結果:
-----修改之前,列表ABC的數據----- a2data a2data1 a2data2 -----修改之後,列表ABC的數據----- a2data a2data666 a2data2
3.3、查找元素
("查"in, not in, index, count)
所謂的查找,就是看看指定的元素是否存在
in, not in
python中查找的常用方法為:
- in(存在),如果存在那麼結果為true,否則為false
- not in(不存在),如果不存在那麼結果為true,否則false
demo
#待查找的列表 nameList = ['a2data','a2data1','a2data2'] #獲取用戶要查找的用戶名稱 findName = input('請輸入要查找的用戶名稱:') #查找是否存在 if findName in nameList: print('在字典中找到了同一個用戶') else: print('沒有找到相同的用戶')
說明:
in的方法只要會用了,那麼not in也是同樣的用法,只不過not in判斷的是不存在
index, count
index和count與字符串中的用法相同
>>> a = ['a', 'b', 'c', 'a', 'b'] >>> a.index('a', 1, 3) # 注意是左閉右開區間 Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: 'a' is not in list >>> a.index('a', 1, 4) 3 >>> a.count('b') 2 >>> a.count('d') 0
3.4、刪除元素
("刪"del, pop, remove)
類比公號中,如果掉粉了,那麼就應該把這個取關粉絲的姓名刪除掉;在開發中經常會用到刪除這種功能。
列表元素的常用刪除方法有:
- del:根據下標進行刪除
- pop:刪除最後一個元素
- remove:根據元素的值進行刪除
demo:(del)
movieName = ['a2data','a2data1','a2data2','a2data3','a2data4','a2data5'] print('------刪除數據之前的展示------') for tempName in movieName: print(tempName) del movieName[2] print('------刪除數據之後的展示------') for tempName in movieName: print(tempName)
結果:
------刪除數據之前的展示------ a2data a2data1 a2data2 a2data3 a2data4 a2data5 ------刪除數據之後的展示------ a2data a2data1 a2data3 a2data4 a2data5
demo:(pop)
movieName = ['a2data','a2data1','a2data2','a2data3','a2data4','a2data5'] print('------刪除數據之前------') for tempName in movieName: print(tempName) movieName.pop() print('------刪除數據之後------') for tempName in movieName: print(tempName)
結果:
------刪除數據之前------ a2data a2data1 a2data2 a2data3 a2data4 a2data5 ------刪除數據之後------ a2data a2data1 a2data2 a2data3 a2data4
demo:(remove)
movieName = ['a2data','a2data1','a2data2','a2data3','a2data4','a2data5'] print('------刪除數據之前------') for tempName in movieName: print(tempName) movieName.remove('a2data3') print('------刪除數據之後------') for tempName in movieName: print(tempName)
結果:
------刪除數據之前------ a2data a2data1 a2data2 a2data3 a2data4 a2data5 ------刪除數據之後------ a2data a2data1 a2data2 a2data4 a2data5
3.5、排序
(sort, reverse)
sort方法是將list按特定順序重新排列,默認為由小到大,參數reverse=True可改為倒序,由大到小。 reverse方法是將list逆置。
>>> a = [1, 4, 2, 3] >>> a [1, 4, 2, 3] >>> a.reverse() >>> a [3, 2, 4, 1] >>> a.sort() >>> a [1, 2, 3, 4] >>> a.sort(reverse=True) >>> a [4, 3, 2, 1]
4、列表的嵌套
4.1 列表嵌套
類似while循環的嵌套,列表也是支持嵌套的 一個列表中的元素又是一個列表,那麼這就是列表的嵌套
schoolNames = [['北京','山西'], ['湖南','天津','深圳'], ['長沙','上海']]
4.2、 應用
一個公號,有5個長期運營,現在要分配其中3個位置,但是有8位運營者等待分配,請編寫程序,完成隨機的分配
#encoding=utf-8 import random # 定義 一個運營管理者的裂變 offices = [[],[],[]] # 定義一個列表用來存儲8位運營者的名字 names = ['A','B','C','D','E','F','G','H'] i = 0 for name in names: index = random.randint(0,2) offices[index].append(name) i = 1 for tempNames in offices: print('運營%d的人數為:%d'%(i,len(tempNames))) i+=1 for name in tempNames: print("%s"%name,end='') print("n") print("-"*20)