day7-容器类型-总结
2018-10-08 本文已影响0人
_桑心人
1.认识列表
-
列表:
是python中容器类的数据类型,可以用来存储多个数据。可变的,有序的。
可变指的是列表中的元素的值和位置以及列表的长度可变 ---> 决定列表可以进行增删改
有序 ---> 决定可以通过下标获取元素
-
列表的自变量:
[元素1,元素2,元素3....]
[] ----> 空列表
代码示例
list1 = [1,23,'a2',True] # 声明一个列表变量list
# 声明一个列表,列表中有三个元素,分别是[1.2],'abc',False
list2 = [
[1, 2],
'abc',
False
]
print(list2[0][0])
list3 = [
]
print(type(list3))
name = '路飞'
names = ['小明','小花','小红',name]
print(names)
运行结果
1
<class 'list'>
['小明', '小花', '小红', '路飞']
2.获取元素
-
1.获取单个元素:
列表[下标]
说明:列表一旦确定,列表中的每个元素就确定。下标的范围0~列表长度-1/-1~列表长度
代码示例
names = ['路飞','娜美','佐罗','山治','罗宾']
print(names[0],names[-4])
print(names[2],names[-2])
运行结果
路飞 娜美
佐罗 山治
-
2.获取部分元素(切片) ---> 结果是一个列表
和字符串切片一样
列表[起始下标:结束下标] ---> 从起始下标开始,获取到结束下标前为止
列表[起始下标:结束下标:步长]
下标不能越界
代码示例
print(names[1:3])
print(names[::2])
print(names[::-1])
运行结果
['娜美', '佐罗']
['路飞', '佐罗', '罗宾']
['罗宾', '山治', '佐罗', '娜美', '路飞']
3.元素的增删改
-
1.增加元素
a.
列表.append(元素) ---> 在列表的最后添加一个元素
只能一个一个添加
代码示例
films = ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女侠']
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中用来删除数据的语法,可以删除任何数据
代码示例
heros = ['盖伦', '维克多', '儿童劫', '提莫', '托儿所', '儿童劫']
del heros[3]
print(heros)
运行结果
['盖伦', '维克多', '儿童劫', '托儿所', '儿童劫']
b.列表.remove(元素) ---> 删除列表中指定的元素
注意:如果元素在列表中有多个,那么只选择删最前面的一个
代码示例
heros.remove('儿童劫')
print(heros)
运行结果
['盖伦', '维克多', '托儿所', '儿童劫']
c.
列表.pop() ----> 将列表中的最后一个元素取出
列表.pop(下标) ----> 将列表中指定下标对应的元素取出
代码如下
beauty = ['余婷', '范冰冰', '周迅', '杨颖', '杨幂', '赵丽颖']
person = beauty.pop()
print(beauty)
print(person)
beauty.pop(1)
print(beauty)
运行结果
['余婷', '范冰冰', '周迅', '杨颖', '杨幂']
赵丽颖
['余婷', '周迅', '杨颖', '杨幂']
-
3.修改表中的元素
列表[下标] = 新值 ----> 修改指定下标对应的元素
代码如下
teachers = ['余婷', '骆昊', '王海飞', '肖世荣']
teachers[0] = 'YuTing'
print(teachers)
运行结果
['YuTing', '骆昊', '王海飞', '肖世荣']
4.练习
-
1.遍历列表中的元素
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
练习:
用一个列表,保存一个班5个学生的成绩,去求这个班的学生的总成绩
代码如下
grade = [78, 80, 95, 85, 89]
sum = 0
for x in grade:
sum += x
print(sum)
运行结果
427
用一个列表,保存多个人的名字(英文的),将列表中所有人的名字首字母大写
代码如下
names = ['ajdj', 'Sjsaj', 'hkkjasd', 'hanhfs', 'gjsdf']
# 方法一:
for index in range(len(names)):
names[index] = names[index].title()
print(names)
# 方法二:
for index in range(len(names)):
name = names[index]
# 判断首字母是小写
if name[0].islower():
names[index] = names[index].title()
print(names)
# 方法三:
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)
运行结果
['Ajdj', 'Sjsaj', 'Hkkjasd', 'Hanhfs', 'Gjsdf']
删除上一个列表中首字母是H的人的名字
代码如下
# 方法一
for name in names[:]:
if name[0] == 'H':
names.remove(name)
print(names)
# 方法二
index = 0
while index < len(names):
name = names[index]
if name[0] == 'H':
del names[index]
index -= 1 # continue
index += 1
print(names)
运行结果
['Ajdj', 'Sjsaj', 'Gjsdf']
用一个列表保存一个班的学生的成绩,删除成绩中不及格的学生
代码如下
grades = [78, 98, 20, 65, 55, 93, 59]
# 方法一
for grade in grades[:]:
if grade < 60:
grades.remove(grade)
print(grades)
# 方法二
grades = [78, 98, 20, 65, 55, 93, 59]
index = 0
while index < len(grades):
if grades[index] < 60:
del grades[index]
continue
index += 1
print(grades)
运行结果
[78, 98, 65, 93]
5.列表的相关运算
-
1.+运算
列表1 + 列表2 ----> 将列表1和列表2中的元素合并,产生一个新的列表
代码示例
print([1, 2, 3] + ['a', 'b', 'c'])
运行结果
[1, 2, 3, 'a', 'b', 'c']
-
2.*运算
列表 * n ----> 将列表中的元素重复n次产生一个新的列表
代码示例
print([1, 2, 3] * 3)
运行结果
[1, 2, 3, 1, 2, 3, 1, 2, 3]
-
3.比较运算
列表1 == 列表2 ----> 判断两个列表中的元素是否相等
补充:is关键字
一个数据有id、value、和type三个元素
id --> 数据在内存里的地址
value --> 数据的值
type --> 数据的类型
python 中变量存储数据的时候存的是数据的地址(id),取出来的是值(value)
== --> 判断值是否相等
is --> 判断地址是否相等(面试)
代码示例
print([1, 2, 3] == [1, 2, 3])
list1 = [1, 2, 3]
list2 = [1, 2, 3]
print(list1 == list2)
print(list1 is list2)
list3 = list1
print(list1 == list3)
print('=========')
运行结果
True
True
False
True
=========
id(变量) --> 显示变量的存储地址
代码示例
print(id(list1), id(list2), id(list3))
运行结果
2796477685640 2796477734984 2796477685640
两个列表比较大小(了解)
代码示例
print([1, 3, 3] > [1, 2, 3, 4]) # 判断元素大小 不是列表长度
运行结果
True
6.列表赋值
代码示例
list1 = ['a', 'aa', 'aaa']
list2 = list1 # 将list1中的数据id赋给list2
list2.append('aaaa')
print(list2)
print(list1)
list3 = list1[:] # 将list1中的数据拷贝到新开辟的list3中
运行结果
['a', 'aa', 'aaa', 'aaaa']
['a', 'aa', 'aaa', 'aaaa']
总结:用一个列表给另一个列表赋值的时候,要注意如果是直接赋值,可能会因为
修改其中一个列表的元素而影响另一个列表,如果不想相互影响,赋值的时候切片
或者拷贝
8.列表相关的方法
-
1.in 和 not in
元素1 in 列表2 ---> 列表2中是否含元素1
元素1 not in 列表2 ---> 列表2中是否不包含元素1
代码示例
print([1, 2, 3] in [[1, 2, 3], 1, 2, 3, 4])
print([1, 2, 3] in [1, 2, 3, 4, 5])
print('abc' in [1, 2, 3, 'abc'])
运行结果
True
False
True
-
2.len()
len(列表) ---> 获取列表的长度
代码示例
print(len([1, 2, 2, 5]))
运行结果
4
-
3.max()和min()
max(列表) --> 获取列表中最大的元素
min(列表) --> 获取列表中最小的元素
要求:
a.列表中的元素类型要一致
b.列表中的元素是支持 > 操作的
代码示例
list1 = [1, 2, 3, 45, 35]
print('max:', max(list1))
运行结果
max: 45
-
4.list()
list(数据) --> 将指定的数据转换成列表
注意:只有序列可以转换成列表
序列:字符,range,列表,字典,元组,集合,迭代器
代码示例
print(list('abcgsd'))
print(list(range(5)))
运行结果
['a', 'b', 'c', 'g', 's', 'd']
[0, 1, 2, 3, 4]
-
5.count()
列表.count(元素) ---> 统计元素出现在列表中的次数
代码示例
names = ['千与千寻', '龙猫', '风之谷', '天空之城']
print(names.count('千与千寻'))
print(names.count('幽灵公主'))
运行结果
1
0
-
6.extend()
列表.extend(序列) ---> 将序列中的元素添加到列表中
代码示例
names.extend('abc')
print(names)
names.extend(range(3))
print(names)
运行结果
['千与千寻', '龙猫', '风之谷', '天空之城', 'a', 'b', 'c']
['千与千寻', '龙猫', '风之谷', '天空之城', 'a', 'b', 'c', 0, 1, 2]
-
7..index()
列表.index(元素) ----> 获取指定元素在列表中的下标
注意:如果元素在列表中有多个,获取最前面的元素的下标
代码示例
names = ['沉默的羔羊', '肖生克的救赎', '阿甘正传', '霸王别姬']
print(names.index('肖生克的救赎'))
运行结果
1
-
8.reverse()
列表.reverse() ---> 将列表中的元素倒序
代码示例
names.reverse()
print(names)
运行结果
['霸王别姬', '阿甘正传', '肖生克的救赎', '沉默的羔羊']
-
9.sort()
列表.sort() ----> 将列表中的元素升序排序(从小到大)
列表.sort(reverse=True) ----> 将列表中的元素降序排序(从大到小)
sorted(列表) ----> 将列表中的元素升序排序后产生一个新的列表(不会改变原列表)
sorted(列表,reverse=True) -----> 将列表中的元素降序排序后产生一个新的列表(不会改变原列表)
要求:
a.列表中的元素类型要一致
b.列表中的元素是支持 > 操作的
代码示例
scores = [12, 78, 45, 94, 15 ]
scores.sort()
print(scores)
scores.sort(reverse=True)
print(scores)
运行结果
[12, 15, 45, 78, 94]
[94, 78, 45, 15, 12]
-
10.clear()
列表.clear() ----> 清空列表的元素
代码示例
scores.clear()
print(scores)
运行结果
[]
-
11.copy()
列表.copy() ----> 将列表中的元素复制产生一个新的列表
代码示例
list1 = [1, 2, 3]
new = list1.copy()
print(new, id(new), id(list1))
运行结果
[1, 2, 3] 3014333243272 3014333292616