容器型数据类型:
列表
类型名(list)
解释:列表是容器型数据类型(一个列表可以同时保存多个数据);将[]作为容器的标志,里面多个元素用逗号隔开:[元素1,元素2,…]
特点:列表是可变的(可变:指的是列表中元素的个数,元素的值,元素的顺序);列表是有序的(每个元素都有位置对应的索引值)
元素的要求:任何类型的数据,都可以作为列表的元素;而且同一个列表可以保存不同类型的数据.
注意:
#空列表(中括号里面有空格也代表是空列表)
#列表元素类型可以一样也可以不一样;
list2=[10,34,'asd',True,None] print(list2) list3=[10,[1,2],30]#只有三个元素 print(list3)#列表里面元素可以换行 list4=[20, 'hello world', [2,5,6], [2,5,9], 7] print(list4)
查-获取列表元素
1)查单个-获取一个元素
语法:
列表[下标]-获取指定下标对应的元素
说明:
列表-可以是任何结果的表达式,一般用于保存列表的变量
[]-固定写法:
下标-下标又叫索引,它是有序序列中元素在序列中的位置信息.
列表中每一个元素都有两个下标值:
从右向左是一个从0开始以此增加的下标值(0表示第一个元素)
从左向右是一个从-1开始依次减小的下标值(-1表示倒数第一个元素,-2表示倒数第二个元素,…)
注意:下标不能越界,下标的有效范围:0~长度减1 和-1~-长度
len(列表)-获取列表中元素的个数(获取列表长度)
nums=[10,45,78,50] print(len(nums)) print(nums[1],nums[-3]) print([10,45,78,50][2],[10,45,78,50][1])#获取78,10
切片-获取部分元素
完整语法:
列表[开始下标:结束下标:步长]
说明:
开始下标,结束下标-下标值:
[开始下标,结束下标)用来确定切片的有效范围,左闭右开.
步长-正整数或者负整数;用正负号来决定获取的方向(正-从前往后;负-从后往前),用绝对值来确定获取元素的时候是否跳着取值,总共跳几个.
:-固定写法
获取原理:
1)如果步长对应的方向 和 开始下标对应的元素到结束下表对应的元素的方向不一致,切片无效,结果是空列表.
2)如果切片有效,先确定有效范围([开始下标,结束下标]),然后在有效范围内根据步长方向按照步长的绝对值获取元素,创建新的列表.
film_names = ['碟中谍', '肖申克的救赎', '霸王别姬', '星际穿越', '阿Q正传', '大话西游', '绿皮书', '这个杀手不太冷'] print(film_names[-1:2:-2])#这个杀手不太冷,大话西游,星际穿越 print(film_names[1:4:-1])#空 print(film_names[0:6:3])#碟中谍,星际穿越, print(film_names[-2:0:-1])#绿皮书,大话西游,阿q正传,星际穿越,霸王别姬,肖申克的救赎 print(film_names[-4:-1:-2])#空 print(film_names[1:4:1]) print(film_names[0:2:1]) print(film_names[2:7:2]) print(film_names[2:-1:2]) print(film_names[-1:-5:-1]) print(film_names[-4:-8:-3]) print(film_names[0:10:1])#获取整个列表 print(film_names[-8:10:1])#获取整个列表 print(film_names[0::1])#****方法三不写结束范围 # 方法一***从前往后如果取到最后一个值,列表可以越界[0:10:1] # 方法二[-8:10:1]
省略语法
a.省略步长:列表[开始下标:结束下标]默认步长为1.
b.省略开始下标:列表[:结束下标:步长]看步长正负,步长为正从0向右开始,步长为负,从最后一个向左开始取值
c.省略结束下标:列表[开始下标::步长]如果步长为正,从左往右,取到最后一个为止,如果步长为负,从右往左,取到最后一个为止.
遍历-一个一个的取,取完
方法一:直接获取元素
for 元素 in 列表:
pass
方法二:先获取元素下标,再根据下标获取元素
for 变量 in range(len(列表)):
(变量取到的是元素的下标)
方法三:
for 下标,元素 in enumerate(列表):
同时获得列表元素和下标
nums = [34, 56, 78, 9, 23] for x in nums: print(x) # 打印nums中所有的偶数 print('--------------------------------') for x in nums: if x % 2 == 0: print(x) # 求nums中所有元素的和 result = 0 for x in nums: result += x print(result) print('-------------------------------------') nums = [34, 56, 78, 9, 23] for x in range(len(nums)): print(x, nums[x]) print('-------------------------------------') nums = [34, 56, 78, 9, 23] for index,item in enumerate(nums): print(index, item)
列表增删改操作
nums = [20, 30] print(nums) # [20, 30] nums.append(100) print(nums) # [20, 30, 100] nums.append('你好') print(nums) # [20, 30, 100, '你好'] nums = [100, 200, 300] print(nums) # [100, 200, 300] nums.insert(-1, 400) print(nums) # [100, 200, 400, 300] nums.insert(0, 1000) print(nums) # [1000, 100, 200, 400, 300]
删-删除列表元素
del 列表[下标]-删除列表中指定下标对应的元素
列表.remove(元素)-删除列表中指定元素(如果元素看不存在会报错;如果元素有多个,则只会删除最前面的那个元素)
列表.pop()-取出列表最后一个元素,并且返回
列表.pop(下标)-取出列表中指定下标对应的元素,并且返回.
nums = [11, 20, 20, 35, 8, 7, 90, 22, 23, 5, 7, 10] del nums[3] print(nums) # [11, 20, 20, 8, 7, 90, 22, 23, 5, 7, 10] nums = [11, 20, 35, 8, 7, 90, 22, 20, 23, 5, 7, 10] nums.remove(20) print(nums) # [11, 35, 8, 7, 90, 22, 20, 23, 5, 7, 10] nums = [11, 20, 35, 8, 7, 90, 22, 20, 23, 5, 7, 10] x = nums.pop() print(nums, x) # [11, 20, 35, 8, 7, 90, 22, 20, 23, 5, 7] x = nums.pop(1) print(nums, x) # [11, 35, 8, 7, 90, 22, 20, 23, 5, 7]
# 列表[下标] = 新元素 nums = [11, 20, 35, 8, 7, 90, 22, 20, 23, 5, 7, 10] nums[1] = 200 print(nums) # [11, 200, 35, 8, 7, 90, 22, 20, 23, 5, 7, 10]
已知一个数字列表,打印列表中所有的奇数
nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x in nums: if x%2!=0: print(x,' ',end='')
已知一个数字列表,打印列表中所有能被能被3整除但是不能被2整除的数
nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x in nums: if x%3==0and x%7!=0: print(x,' ',end='')
已知一个数字列表,计算所有偶数的和
result=0 nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x in nums: if x%2==0: result+=x print(result)
已知一个数字列表,统计列表中十位数是1
的数的个数
result=0 nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x in nums: c=x%100//10 result+=c print(result)
已知一个列表,获取列表中下标为奇数是所有元素(从0开始的下标值)
result=0 nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x in range(len(nums)): if x%2==1: print(x,nums[x])
例如: list1 = [10, 20, 5, 34, 90, 8]
结果:[20, 34, 8]
已知一个数字列表,将列表中所有元素乘以2
list=[] nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17] for x,y in enumerate(nums): c=y*2 list.append(c) print(list)
例如: nums = [10, 3, 6, 12] 乘2后: nums = [20, 6, 12, 24]
已知一个列表,获取列表的中心元素
nums=[11,12,6,9,52,78,35,47,255,56,59,21,58,23,17,15] for x in range(len(nums)): pass if x%2==0: print(nums[int(x/2)]) else: print(nums[int(x/2)],nums[int(x/2)+1])
例如:nums = [10, 2, 6, 12] -> 中心元素为: 2和6
nums = [10, 2, 6, 12, 10] -> 中心元素为:6
已知一个列表,获取列表中所有的整型元素
list=[] list1 = [10, 1.23, 'abc', True, 100, 'hello', '20', 5] for x in list1: if type(x)==int: list.append(x) print(list)
例如:list1 = [10, 1.23, ‘abc’, True, 100, ‘hello’, ‘20’, 5]
结果是: [10, 100, 5]
定义一个列表保存多个学生的分数,删除列表中所以低于60分的值
例如: scores = [45, 60, 89, 30, 12, 59, 99, 80, 71, 66] 删除后: scores = [60, 89, 99, 80, 71, 66]
已知一个列表保存了多个学生的姓名,要求去掉列表中重复的名字
例如:names = [‘小明’, ‘张三’, ‘李四’, ‘张三’, ‘张三’, ‘小明’, ‘王五’, ‘王五’]
去重后:names = [‘小明’, ‘张三’, ‘李四’, ‘王五’]
已知一个数字列表,获取列表中值最大的元素 (不能使用max函数)
已知两个有序列表(列表中的元素已经按照从小到大的方式排好序),要求合并两个列表,合并后元素还是从小到大排序
例如: list1 = [10, 23, 39, 41, 52, 55, 80] list2 = [9, 38, 55, 70]
合并后的结果: [9, 10, 23, 38, 39, 41, 52, 55, 55, 70, 80]
已知一个有序数字列表(从小到大),输入任意一个数字,将输入的数字插入列表中,要求插入后列表仍然保持从小到大排序的关系
例如: list1 = [10, 23, 45, 67, 91] 输入: 50 -> list1 = [10, 23, 45, 50, 67, 91]