1.什么是列表
- 列表:是python中的容器数据类型,可以用来存储多个数据,可变的,有序。
- 可变:指的是列表中的元素的值和位置以及列表的长度可变
- 声明一个变量:list1 = [元素1,....]
有序指的是列表确定后每个元素的位置固定
可对列表进行增删改
2.自变量
- []:有中括号的都是列表
- 如:[元素1,元素2,.....]
3.列表中的的元素可以是任何数据类型(重点)
- 如:变量,int,float,bool,str,list,dict,元祖,set,函数,类的对象
4.list中取数据
names = ['小米','小明','小红']
print(names)
5.获取单个元素
- 语法:列表[下标]
- 说明:列表一旦确定列表中的每个元素下标确定。
- 范围:0 到 列表长度-1
-1 到 -列表长度
6.获取部分元素(切片)
- 列表[起始下标:结束下标:步长]
- 注意:切片后还是列表并且和str一样含头不含尾
7.增加元素
a.
列表.append(元素):在列表的最后添加一个元素
b.
列表.insert(下标,元素)
在制定的下标前添加制定的元素
films.append('美国队长')
print(films)
films.insert(1,'钢铁侠')
print(films)
8.删除元素
a.
del 列表[下标]
删除指定位置的元素
del语句是python中来删除数据的语法,可以删除任何内容
b.
list.remove(元素)
删除列表中制定的元素
如果列表中有多个相同的元素,则只删除在列表中第一次出现的元素
c.
list.pop() :将列表中的最后一个元素取出
list.pop(下标) :将下标对应的元素取出来
heos = ['盖伦','提莫','维克托']
del heos[1]
print(heos)
heos.remove('维克托')
print(heos)
beauty = ['复联3', '钢铁侠', '熊出没', '黑客帝国', '美国队长']
i = beauty.pop() # 取出,相对于列表而言是删除操作,但还存在内存中
print(beauty,i)
j = beauty.pop(1)
print(beauty,j)
9.修改元素
list[下标] = 值
修改制定位置的元素值
teachers = ['xiaoming','王海飞','haha']
teachers[-1] = '张三'
print(teachers)
10.遍历列表
- 循环编列列表,获取列表元素
number = [12,34,5]
for x in number:
print(x)
for index in range(len(number)):
print(index,number[index])
11.用一个列表保存一个班5个学生的成绩,求这个班的总成绩
scores = [72,62,85,90,92]
sum1 = 0
for x in scores:
sum1 += x
print('总分:%d'%(sum1))
12.用一个列表保存多个人的名字(英文),将列表中的每个名字首字母大写
names = ['xiaoming', 'xiaohong', 'Huliang', 'hanhan', 'lisi', 'zhangsan', 'hahaha']
for index in range(len(names)):
names[index] = names[index].title()
print(names)
13.删除上一个列表中首字母是H的人的名字
for name in names[:]: # names[:] 相当于复制一份,修改备份的列表
# print(names)
if name[0] == 'H':
names.remove(name)
print(names)
练习:用列表保存有个班的学生成绩,删除不及格的分数
scores = [85,62,50,52,68,90,70]
for score in scores[:]:
if score < 60:
scores.remove(score)
print(scores)
14.+ 运算
a.
列表1 + 列表2 + ....+
将列表中的元素合并,产生一个新的列表
b.
列表 * n :将列表元素重复n次,并产生一个新的列表
c.
比较运算:list1 == list2 判断两个列表中的元素是否相等(长度,元素,位置)
> 和 < :比较元素的大小而不是长度,一般不用
d.
比较是否相等有两中方式:== 和 is
一个变量有id、value、type三个元素
类型 | 解释 |
---|---|
id | 地址(内存中的地址) |
value | 变量值 |
type | 数据类型 |
- python变量存储数据时存储的是变量的地址(id),取出来用的是值(value)
类型 | 解释 |
---|---|
== | 判断值是否相等 |
is | 判断是变量地址是否相等(id) |
print([1, 2, 3] + ['a', 'b', 'c'])
print([1, 2, 3] * 3)
15.列表赋值问题
list1 = ['a','b','c']
list2 = list1
list2.append('d')
print(list1)
list3 = list1[:]
list3.pop()
print(list3)
list4 = list3.copy()
list4.append('123')
print(list4)
当用一个列表给另一个列表赋值时,要注意如果直接赋值可能会因为修改初始转状态的列表,如果不想影响初始列表,则赋值时对初始列表进行切片或拷贝
16.in和not in
元素n in list2 :判断元素n是否是列表2的元素(指1作为2的元素)
元素n in list2 :判断元素n是否不是列表2的元素(指1作为2的元素)
17.len()求列表长度
列表长度及列表元素个数
18.max()和min():获取列表中最大和最小元素
注意:列表中的元素类型要一致,并且支持比较大小
19.list() :将指定的数据转换成列表
只有序列可以转换成列表(int不行)
序列:字符,range,list,字典,元祖,集合,迭代器
20.count()
list.count(元素) :获取指定元素在列表中的个数(出现次数)
21.extend()
list.extend(序列) :将序列中的元素添加到列表中
22.index()
list.index(元素) :获取指定元素在列表中对应的下标
注意:当一个列表中有多个元素时,只取第一个出现的元素下标,
当元素不在列表中时,会报错
23.reverse()
list.reverse() :将列表中的元素倒序
24.sort() 与 sorted()
list.sort() :将列表中的元素升序排序
list.sort(reverse = True) :将列表中的元素降序排序
注意:列表中的元素类型要一致,并且支持比较大小
sorted(列表) :也能排序,但不会影响初始列表,而是产生一个新的列表(升序排序)
sorted(reverse = True) 降序排序
25.clear()
list.clear() :清空列表中的元素
26.copy()
list.copy() :将列表中的元素复制一份产生一个新的列表和列表[:]功能一样
print('abc' in [1,2,'abc'], max([1,8,2]), min([5,9,4]))
print(list('abc'))
print(list(range(5)))
names = ['千与千寻', '龙猫', '哈儿的移动城堡', '千与千寻']
print(names.count('千与千寻'), names.count('幽灵公主'))
names.extend('abc')
print(names) # ['千与千寻', '龙猫', '哈儿的移动城堡', '千与千寻', 'a', 'b', 'c']
films = ['复联3','熊出没','黑客帝国','熊出没']
print(films.index('黑客帝国'))
print(films.index('熊出没'))
films.reverse()
print(films)
scores = [58,95,62,74,80]
scores.sort()
print(scores)
scores.sort(reverse = True)
print(scores)