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)