1.认识列表(list):
1.什么是列表
是python中的容器类的数据类型,可以用来存储多个数据。可变的,有序的。
可变指的是列表中的元素的值和位置以及列表的长度可变 --->决定列表可以进行增删改
有序 --->决定可以通过下标来获取元素
2.字面量:
[元素1, 元素2, 元素3....]
[] ---> 空列表
列表中的元素可以是任何类型的数据 -->包括整数、浮点数、布尔、字符串、列表、字典、元祖、集合、函数、类的对象等
list1 = [23, 1.87, 'abc'] # 声明一个变量list1,给它赋了一个列表。列表有三个元素
声明一个列表,列表中有三个元素,分别是[1,2], 'abc', False
list2 = [
[1,2],
'abc',
False
]
list3 = [
{'a': 10},
{'abc': True}
]
print(type(list3)) #<class 'list'>
<class 'list'>
注意:变量也可以作为列表的元素
name = '路飞'
names = ['小明', '小花', '小红', name]
print(names)
['小明', '小花', '小红', '路飞']
3.获取列表的元素:
1.获取单个元素
列表[下标]
说明:列表一旦确定,列表中的每个元素的下标就确定了。下标的范围0~列表长度-1 / -1~列表长度
names = ['路飞', '娜美', '佐罗', '山治', '罗宾']
print(names[0], names[-4])
路飞 娜美
print(names[20]) # 下标不能越界
2.获取部分元素(切片) ---> 结果是个列表
和字符串切片一样。
列表[起始下标:结束下标] --> 从起始下标开始,获取到结束下标前为止
列表[起始下标:结束下标:步长]
print(names[1:3])
print(names[:4:2])
print(names[::-1])
print(names[:])
['娜美', '佐罗'] ['路飞', '佐罗'] ['罗宾', '山治', '佐罗', '娜美', '路飞'] ['路飞', '娜美', '佐罗', '山治', '罗宾']
4.元素的增删改:
films = ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校']
1.增(增加元素)
a.
列表.append(元素) ---> 在列表的最后添加一个元素
films.append('美国队长')
print(films)
films.append('恐怖游轮')
print(films)
['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长']
['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']
b.
列表.insert(下标,元素) ---> 在指定的下标前去添加指定的元素
films.insert(1, '双瞳')
print(films)
films.insert(0, '雷神')
print(films)
['绿巨人', '双瞳', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']
['雷神', '绿巨人', '双瞳', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']
2.删(删除列表中的元素)
a.
del 列表[下标] ---> 删除列表中指定位置的元素
注意:
del语句是python中用来删除数据的语法,可以删除任何数据
a = 10
del a
print(a)
heros = ['盖伦', '儿童劫','维克拖', '提姆', '托儿索', '儿童劫']
del heros[-2]
print(heros)
['盖伦', '儿童劫', '维克拖', '提姆', '儿童劫']
b.
列表.remove(元素) ---> 删除列表中指定的元素
注意:如果这个元素在列表中有多个,只删最前面的那一个
heros.remove('儿童劫')
print(heros)
['盖伦', '维克拖', '提姆', '托儿索', '儿童劫']
c.
列表.pop() ---> 将列表中的最后一个元素取出
列表.pop(下标) ---> 将列表中指定下标对应的元素取出
beauty = ['余婷', '范冰冰', '周迅', '杨颖', '杨幂', '赵丽颖']
person = beauty.pop()
print(beauty, person)
person = beauty.pop(1)
print(beauty, person)
['余婷', '范冰冰', '周迅', '杨颖', '杨幂'] 赵丽颖
['余婷', '周迅', '杨颖', '杨幂'] 范冰冰
3.改(修改列表中的元素)
列表[下标] = 新值 ---> 修改指定下标对应的元素
teachers = ['余婷', '骆昊', '王海飞', '肖世荣']
teachers[0] = 'YuTing'
print(teachers)
5.练习:
for循环变量列表,拿到的就是列表中的每个元素
numbers = [12, 34, 56, 45, 90, 89]
for x in numbers:
print(x)
for index in range(len(numbers)):
print(index, numbers[index])
12 34 56 45 90 89 0 12 1 34 2 56 3 45 4 90 5 89
1.用一个列表,保存一个班5个学生的成绩,去求这个班的学生的总成绩
scores = [89, 78, 90, 56, 89]
sum1 = 0
for score in scores:
sum1 += score
print(sum1)
402
2.用一个列表,保存多个人的名字(英文的), 将列表中所有的人的名字首字母大写
names = ['zhangsan', 'XiaoMing', 'lisi', 'wangwu']
# 方法1:
# 下标
index = 0
for name in names:
# 取出首字母
first = name[0]
# 判断首字母是否是大写
if first.isupper():
index += 1
continue
# 新的名字
new_name = name.title()
# 修改名字
names[index] = new_name
index += 1
print(names)
names = ['zhangsan', 'Hu', 'HaHa', 'XiaoMing', 'lisi', 'wangwu', 'Head']
# 方法二:
for index in range(len(names)):
name = names[index]
# 如果是小写
if name[0].islower():
names[index] = name.title()
print(names)
3.删除上一个列表中,首字母是H的人的名字
names = ['Zhangsan','XiaoMing', 'Lisi', 'Wangwu']
names[:] = ['Zhangsan','HaHa', 'XiaoMing', 'Lisi', 'Wangwu', 'Head']
for name in names[:] 相等于:
new = names[:]
for name in new:
for name in names[:]:
if name[0] == 'H':
names.remove(name)
print(names)
['Zhangsan', 'XiaoMing', 'Lisi', 'Wangwu']
['zhangsan','HaHa','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
index = 0 zhangsan
index = 1 HaHa ['zhangsan','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
index = 1 Hu ['zhangsan', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
index = 1 XiaoMing
index = 2 Lisi
index = 3 wangwu
index = 4 Huo ['zhangsan', 'XiaoMing', 'lisi', 'wangwu']
index = 4
names = ['zhangsan', 'HaHa','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
index = 0
while index < len(names):
name = names[index]
if name[0] == 'H':
del names[index]
continue
index += 1
print(names)
['zhangsan', 'XiaoMing', 'lisi', 'wangwu']
用一个列表保存一个班的学生的成绩,删除成绩中不及格的学生
grade = [12, 78, 98, 78]
new = grade[:]
for x in new:
if x < 60:
grade.remove(x)
print(grade, new, grade[:])
[78, 98, 78] [12, 78, 98, 78] [78, 98, 78]
6.列表相关运算:
1.+
列表1 + 列表2 ---> 将列表1和列表2中的元素合并,产生一个新的列表
list1 = [1, 2, 3]
list2 = ['a', 'b', 'c']
print(list1 + list2)
print(list1)
[1, 2, 3, 'a', 'b', 'c']
[1, 2, 3]
2.*
列表*n ---> 将列表中的元素重复n次,产生一个新的列表
print(list1*3)
[1, 2, 3, 1, 2, 3, 1, 2, 3]
3.比较运算
- 列表1 == 列表2 ---> 判断两个列表中的元素是否相等
print([1, 2, 3] == [2, 1, 3]) # False
print([1, 2, 3] == [1, 2, 3]) # True
- 补充:比较是否相等的两种方式,== 和 is
一个数据有id、value和type三个元素。
id --> 地址(数据在内存中存储的地址)
value --> 数据的值
type --> 数据的类型
python中变量存储数据的时候存的时候数据的地址(id),取出来用的值(value)
== --> 判断的是值是否相等
is --> 判断的是地址是否相等(面试!)
list1 = [1, 2, 3]
list2 = [1, 2, 3]
list3 = list1
print(id(list1), id(list2), id(list3))
print(list1 == list2) # True
print(list1 is list2) # False
print(list1 is list3) # True
(了解)两个列表比较大小,比较的是每个元素的大小
print([1, 2, 5] > [10, 2, 3, 4])
7.列表赋值:
list1 = ['a', 'aa', 'aaa']
list2 = list1 # 将list1中的数据的id赋给list2
list2.append('aaaa')
print(list2)
print(list1)
['a', 'aa', 'aaa', 'aaaa']
['a', 'aa', 'aaa', 'aaaa']
list3 = list1[:] # 将list1中的数据拷贝一份,存到新的内存区域中,然后将新的地址给list3
list3.pop(0)
print(list3)
print(list1)
['aa', 'aaa', 'aaaa']
['a', 'aa', 'aaa', 'aaaa']
总结:用一个列表给另外一个列表赋值的时候,要注意如果是直接赋值,
可能会因为修改其他一个列表的元素而影响另外一个列表。如果不想相互影响,赋值的时候赋切片或者拷贝
list1 = [1, 2, 3]
list2 = list1
list1 = [1, 200, 3]
list1[1] = 'abc'
print(list1, list2)
['aa', 'aaa', 'aaaa']
['a', 'aa', 'aaa', 'aaaa']
8.列表相关的方法:
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
print('abc' in [1, 2, 3, 'abc'])
2.len()
len(列表) --> 获取指定列表的长度
print(len([1, 2, 3, 4, 5]))
5
3.max()和min()
max(列表) --> 获取列表中最大的元素
min(列表) --> 获取列表中最小的元素
要求:a.列表中的元素类型要一致 b.列表中的元素是支持>操作的
list1 = [1, 2, 3, 100, 90]
print('max:',max(list1))
print('min:', min(list1))
max: 100
min: 1
list2 = [lambda a:a, lambda x:x*2]
print(max(list2))
IndentationError: unexpected indent
4.list()
list(数据) ---> 将指定的数据转换成列表
注意:只有序列可以被转换成列表
序列:字符,range, 列表,字典,元祖,集合,迭代器
print(list('abcde'))
print(list(range(5)))
# print(list(100)) # TypeError
5.count()
列表.count(元素) --> 获取指定的元素在列表中的个数
names = ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻']
print(names.count('千与千寻'))
print(names.count('幽灵公主'))
2
0
6.extend()
列表.extend(序列) --> 将序列中的元素添加到列表中
names.extend('abc')
print(names)
names.extend(range(3))
print(names)
names.extend(['11', '22'])
print(names)
['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c']
['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c', 0, 1, 2]
['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c', 0, 1, 2, '11', '22']
7.index()
列表.index(元素) --> 获取指定的元素在列表中的下标
注意:如果元素在列表中有多个,获取最前面的元素的下标
names = ['沉默的羔羊', '肖生克的救赎', '阿甘正传', '霸王别姬', '阿甘正传']
print(names.index('肖生克的救赎'))
print(names.index('阿甘正传'))
print(names.index('abc')) # 如果元素不存在,会报错, ValueError
1
2
8.reverse()
列表.reverse() --> 将列表中的元素倒序
names.reverse()
print(names)
['阿甘正传', '霸王别姬', '阿甘正传', '肖生克的救赎', '沉默的羔羊']
9.sort() 和 sorted
- 列表.sort() --> 将列表中的元素升序排序(从小到大)
- 列表.sort(reverse=True) --> 将列表中的元素降序排序(从大到小)
- sorted(列表) --> 将列表中的元素升序排序后产生一个新的列表(不会改变原列表)
- sorted(列表,reverse=True) --> 将列表中的元素降序排序后产生一个新的列表(不会改变原列表)
要求:a.列表中的元素类型要一致 b.列表中的元素是支持>操作的
scores = [12, 89, 78, 90, 78, 100]
scores.sort()
print(scores)
scores = [12, 89, 78, 90, 78, 100]
scores.sort(reverse=True)
print(scores)
scores = [12, 89, 78, 90, 78, 100]
new_scores = sorted(scores, reverse=True)
print(new_scores)
[12, 78, 78, 89, 90, 100]
[100, 90, 89, 78, 78, 12]
[100, 90, 89, 78, 78, 12]
10.clear()
列表.clear() --> 清空列表中的元素
scores.clear()
print(scores)
[]
11.copy()
列表.copy() --> 将列表中的元素复制一份产生一个新的列表,和列表[:]的功能一样
list1 = [1, 2, 3, 'abc']
new = list1.copy()
print(new, id(list1), id(new))
[1, 2, 3, 'abc'] 31860456 31861816