一、认识列表(list)
1.什么是列表
是python中的容器类的数据类型,可以用来存储多个数据, 可变的,有序的。
可变指的是列表中的值和位置以及列表的长度可变 —>决定列表可以进行增删改
有序 –> 决定可以通过下标来获取元素
2.字面量
[元素1,元素2,元素3,,…]
[] –>空列表
列表中的元素可以是任何类型的数据 –>包括整数,布尔,浮点,字符串,字典等
二、获取列表元素
1.获取单个元素
列表[下标]
说明:列表一旦确定,列表中每个元素的下标就确定了。下标的范围0~列表长度-1/-1~列表长度
names = [‘路飞’, ‘娜美’, ‘索隆’, ‘山治’, ‘罗宾’]
print(names[0], names[-4])
print(names[2])
输出的结果为:路飞 娜美
索隆
2.获取部分元素(切片) —>结果是个列表
和字符串切片一样。
列表[起始下标:结束下标] –>从起始下标开始,获取到结束下标前为止
列表[起始下标:结束下标:步长]
print(names[1:3])
print(names[:4:2])
print(names[::-1])
print(names[:])
输出的结果为:
[‘娜美’, ‘索隆’]
[‘路飞’, ‘索隆’]
[‘罗宾’, ‘山治’, ‘索隆’, ‘娜美’, ‘路飞’]
[‘路飞’, ‘娜美’, ‘索隆’, ‘山治’, ‘罗宾’]
三、增删改
films = [‘绿巨人’, ‘钢铁侠’, ‘蜘蛛侠’, ‘神奇女侠’]
1.增(增加元素)
a.列表.append(元素)—>在列表的最后添加一个元素
films.append(‘美国队长’)
print(films)
输出的结果为:[‘绿巨人’, ‘钢铁侠’, ‘蜘蛛侠’, ‘神奇女侠’, ‘美国队长’]
b.列表.insert(下标,元素) —>在指定的下标前去添加指定的元素
films.insert(1, ‘雷神’)
print(films)
输出的结果为:[‘绿巨人’, ‘雷神’, ‘钢铁侠’, ‘蜘蛛侠’, ‘神奇女侠’, ‘美国队长’]
2.删(删除列表中的元素)
a.del 列表[下标] —> 删除列表中指定位置的元素、
注意:del语句是python中用来删除数据的语法,可以删除任何数据
b.列表.remove(元素) —>删除列表中的指定元素
注意:如果这个元素在列表中有多个,只删除最前面的那一个
heros=[‘盖伦’, ‘维克托’, ‘托儿索’, ‘儿童劫’]
heros.remove(‘儿童劫’)
print(heros)
输出的结果为:[‘盖伦’, ‘维克托’, ‘托儿索’]
c.列表.pop() —>将列表中最后一个元素取出
列表.pop(下标) —>将列表中指定下标对应的元素取出
beauty = [‘赵丽颖’, ‘范冰冰’, ‘周迅’, ‘杨颖’, ‘杨幂’]
person = beauty.pop()
print(beauty, person)
person = beauty.pop(1)
print(beauty, person)
输出的结果为:
[‘赵丽颖’, ‘范冰冰’, ‘周迅’, ‘杨颖’] 杨幂
[‘赵丽颖’, ‘周迅’, ‘杨颖’] 范冰冰
3.改(修改列表中的元素)
列表[下标] = 新值 —>修改指定下标对应的元素
四、练习
1.遍历列表中的元素
numbers = [12, 34, 56, 5, 25]
for x in numbers:
print(x)
for index in range(len(numbers)):
print(index, numbers[index])
1.用一个列表,保存一个班5个学生的成绩,去求整个班的学生的总成绩
grade = [85, 87, 94, 89, 98]
sum1 =0
for y in grade:
print(y)
sum1 += y
print(sum1)
输出的结果为:453
2.用一个列表,保存多个人的名字(英文的),将列表中所有人的名字首字母大写
方法一
names = [‘asa’, ‘Her’, ‘sher’, ‘Wu’]
index =0
for namein names:
# 取出首字母
first = name[0]
# 判断首字母是否是大写
if first.isupper():
index +=1
continue
# 新的名字
new_name = name.title()
names[index] = new_name
index +=1
print(names)
# 方法二
names = [‘asa’, ‘Her’, ‘sher’, ‘Wu’]
for indexin range(len(names)):
name = names[index]
# 判断首字母是否是小写,如果小写就变为大写
if name[0].islower():
names[index] = name.title()
print(names)
输出的结果为:
[‘Asa’, ‘Her’, ‘Sher’, ‘Wu’]
# 3.删除上一个列表中,首字母是H的人的名字
names = [‘asa’, ‘Her’, ‘HaHa’, ‘sher’, ‘Wu’, ‘Head’]
for namein names[:]:
if name[0] ==’H’:
names.remove(name)
print(names)
# 方法二
names = [‘asa’, ‘Her’, ‘HaHa’, ‘sher’, ‘Wu’, ‘Head’]
index =0
while index<len(names):
name = names[index]
if name[0] ==’H’:
del names[index]
continue
index +=1
print(names)
输出的结果为:
[‘asa’, ‘sher’, ‘Wu’]
# 用一个列表保存一个班的学生的成绩,删除成绩中不及格的学生
scores = [23, 45, 78, 32, 90, 89, 1]
for i in scores[:]:
if i <60:
scores.remove(i)
print(scores)
输出的结果为:
[78, 90, 89]
五、列表相关运算
1.+
列表1+列表2 —>将列表1和列表2中的元素合并,产生一个新的列表
2.*
列表*n—>将列表中的元素重复n次,产生一个新的列表
# 3.比较运算
列表1 == 列表2 —>判断两个列表中的元素是否相等
补充:比较是否相等的两种方式,==和is
一个变量有id、value和type三个·元素
id –>地址(数据在内存中存储的地址)
value–>数据的值
type–>数据的类型
python中变量存储数据的时候存的是数据的地址(id),取出来用的值(value)
== – >判断的是值是否相等
is –>判断的地址是否相等
六、列表相关的方法
1.in和not in
列表n in 列表2 — > 列表n是否是列表2的元素
列表n not in 列表2 — > 列表n是否不是列表2的元素
print([1, 2, 3]in [1, 2, 3, 4, 5]) # False
print([1, 2, 3]in [[1, 2, 3], 2, 3, 4]) # True
2.len()
len(列表) —>获取指定列表的长度
print(len([1, 2, 3]))
输出的结果为:2
3.max()和minx()
max()—>获取列表中最大的元素
min()—>获取列表中最小的元素
要求:a.列表中的元素类型要一致
b.列表中的元素是支持>操作的
list1 = [1, 2, 3, 4, 5]
print(‘max:’, max(list1))
输出的结果为:max:5
4.list()
list(数据) —>将指定的数据转换为列表
注意:只有序列可以转换为列表
序列:字符,range,列表,字典,元祖,集合,迭代器
print(list(‘abcdef’))
print(list(range(5)))
输出的结果为:
[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’]
[0, 1, 2, 3, 4]
5.count()
列表.count(元素)—>获取指定的元素在列表中的个数
names = [‘千与千寻’, ‘龙猫’, ‘哈尔的移动城堡’, ‘风之谷’]
print(names.count(‘千与千寻’))
输出的结果为: 1
6.extend()
列表.extend(序列) –>将序列中的元素添加到列表中
names = [‘千与千寻’, ‘龙猫’, ‘哈尔的移动城堡’, ‘风之谷’]
names.extend(‘abc’)
print(names)
输出的结果为:
[‘千与千寻’, ‘龙猫’, ‘哈尔的移动城堡’, ‘风之谷’, ‘a’, ‘b’, ‘c’]
7.index()
列表.index(元素)—>获取指定元素在列表中的下标
注意:如果元素在列表中有多个,获取最前面的元素的下标,如果元素不存在,会报错
8.reverse()
列表.reverse() —>将列表中的元素倒序
9.sort()
列表.sort()–>将列表中得元素升序排序(从小到大)
列表.sort(reverse=True)—>将列表中的元素降序排序(从大到小)
sorted(列表) —>将列表中的元素升序排序后生成一个新的列表(不改变原来列表)
sorted(列表, reverse=True) —>将列表中的元素降序排序后生成一个新的列表(不改变原来列表)
要求:a.列表中的元素类型要一致
b.列表中的元素是支持>操作的
score = [12, 89, 78, 90, 78, 100]
score.sort(reverse=True)
print(score)
score = [12, 89, 78, 90, 78, 100]
new_score =sorted(score)
print(score)
score = [12, 89, 78, 90, 78, 100]
new_score =sorted(score, reverse=True)
print(score)
10.clear()
列表.clear() –>清空列表中的元素
11.copy()
列表.copy() —>将列表中的元素复制一份产生一个新的列表,和列表[:]的功能一样
给出一个列表:numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121]
1.已知一个列表,求列表中⼼心元素。
numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121]
n =len(numbers)
if n%2 !=0:
a=n//2
print(numbers[a-1], numbers[a])
else:
a = n/2
print(numbers[a])
输出的结果为:32 90
2.已知一个列表,求所有元素和。
sum1=0
for xin numbers:
sum1 += x
print(sum1)
输出的结果为:756
3.已知一个列表,输出所有奇数下标元素。
numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121]
n = [] #添加一个空列表
for i in range(0, len(numbers)):
if numbers[i] %2:
n.append(i)
print(n)
输出的结果为:
[0, 1, 5, 6, 7, 8]
4.已知一个列表,输出所有元素中,值为奇数的。
list1 = []
for iin numbers[:]:
if i %2:
list1.append(i)
print(list1)
输出的结果为:
[23, 45, 89, 123, 155, 121]
5.已知一个列表,将所有元素乘⼆。
list2 = []
for iin numbers[:]:
list2.append(i *2)
print(list2)
输出的结果为:
[46, 90, 156, 64, 180, 178, 246, 310, 242]
6.已知一个列表,将所有元素加到第一个元素中。
list3 = numbers
sum1 =0
for x in numbers:
sum1 += x
list3[0] = sum1
print(list3)
输出的结果为:
[756, 45, 78, 32, 90, 89, 123, 155, 121]
7.已知一个列表A,将奇数位置元素存到B列表中,偶数元素存到C列表中。
B= numbers[1::2]
C= []
for i in numbers[:]:
if not i %2 :
C.append(i)
print(B, C)
输出的结果为:
[45, 89, 123, 155, 121] [756, 78, 32, 90]
8.把A列表的前5个元素复制到B列表中。
list2 = []
for i in numbers[0:5]:
list2.append(i)
print(list2)
10.有一个长度是10的列表,列表内有10个不重复的数字,要求按从大到小排序。
numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121, 152]
numbers.sort(reverse=True)
print(numbers)
输出的结果为:
[155, 152, 123, 121, 90, 89, 78, 45, 32, 23]
11.有一个长度是10的列表,要求删除某一个位置的元素
numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121, 152]
del numbers[4]
print(numbers)
输出的结果为:
[23, 45, 78, 32, 89, 123, 155, 121, 152]
12.有一个长度是10的列表,按递增排列,用户输⼊一个数,插入适当位置。
numbers = [23, 45, 78, 32, 90, 89, 123, 155, 121, 152]
numbers.sort()
print(numbers)
n = int(input(‘请输入一个数字:’))
if n <numbers[0]:
numbers.insert(0,n)
else:
for i in range(1,len(numbers)):
if numbers[i-1] < n < numbers[i]:
numbers.insert(i,n)
print(numbers)
输出的结果为:
请输入一个数字:45
[23, 32, 45, 78, 90, 121, 123, 152, 155]
13.有一个长度是10的列表,数组内有10个人名,要求去掉重复的
names= [‘小明’,’小花’,’小红’,’小强’,’张三’,’李四’,’王五’,’小花’,’张三’,’小明’, ‘张三’]
list = []
for name in names:
if name not in list:
names.append(name)
print(list)
输出的结果为:
[‘小明’, ‘小花’, ‘小红’, ‘小强’, ‘张三’, ‘李四’, ‘王五’]
14.把A列表的第三到第六位之间的元素删除。
A =[1, 2, 3, 4, 5 ,6, 7, 8, 9]
for x in A[3:5]:
A.append(x)
print(A)
15.已知A列表,B列表,定义一个列表C,要求C包含A,B数组B的数据(⽆无重复值)。
A = [21,33,23,34,55,66,34,76,21,44]
B = [22,33,44,55,66,77,88,99,33,44]
C = []
for x in A:
if x not in C:
C.append(x)
for i in B:
if i not in C:
C.append(i)
print(C)