一、认识列表(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() --->将列表中的元素复制一份产生一个新的列表,和列表[:]的功能一样