2021-01-27 第6课 序列,列表,for型循环与遍历列表

逻辑教育.png

break和continue(上节课遗留知识点)

• break 可以用来立即退出循环语句,包括else语句
• continue 用来跳过当初循环


序列(sequence)

基本概念

  • 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引
  • 数据结构指计算机中数据存储的方式

序列的分类

  • 可变序列(序列中的元素可以改变):例如 列表(list)
  • 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)
列表(list)
  • 列表是Python中的一个对象
列表的作用
  • 1.列表中可以保存多个有序的数据
  • 2.列表是用来存储对象的对象
列表的使用
  • 列表的创建:通过[]来创建一个空列表
#创建一个空列表
a = []

#通过赋值来创建一个列表,列表可以保存任意元素
b = [1,2,3,'hello',(1,2),[1,1.1],None]
切片
  • 语法: 列表[起始 : 结束 : 步长]
  • 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素
  • 起始位置和结束位置的索引可以不写
  • 如果省略结束位置, 则会从当前的开始位置一直截取到最后
  • 如果省略开始位置, 则会从第一个元素截取到结束的元素,但是不包括结束的元素
  • 如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素
  • 步长表示每次获取元素的间隔,默认是1(可以省略不写)
  • 步长不能是0,但可以是是负数
  • 切片是指从现有列表中获得一个子列表
>>> a = ['a','b','c','d','e','f']
#取出第2,3位置的元素
>>> a[2:4]
['c', 'd']

#从0取到4,步长为2,即取0,2,4号位置的元素
>>> a[:5:2]
['a', 'c', 'e']
#取出第2号到最后的元素
>>> a[2:]
['c', 'd', 'e', 'f']
#逆序取出所有元素
>>> a[::-1]
['f', 'e', 'd', 'c', 'b', 'a']
>>> 
  • 通过切片来获取指定的元素
#取出第3号位置元素
>>> a[3]
'd'

通用操作

'+' 和 '*'

1.'+' 可以将两个列表拼接成一个列表
2.'*' 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)

>>> a = ['a', 'b', 'c', 'd', 'e', 'f']
#相当于拼接列表
>>> a[:3]+a[4:]
['a', 'b', 'c', 'e', 'f']
>>> 
#a*2 等价于 a+a
>>> a*2
['a', 'b', 'c', 'd', 'e', 'f', 'a', 'b', 'c', 'd', 'e', 'f']
#乘以0或负数则清空列表,神奇的操作!!!
>>> a*0
[]
>>> a*-1
[]
>>> a*-2
[]
#a*3 等价于 a+a+a
>>> a*3
['a', 'b', 'c', 'd', 'e', 'f', 'a', 'b', 'c', 'd', 'e', 'f', 'a', 'b', 'c', 'd', 'e', 'f']
>>> 

注意:如果是乘法运算,乘号后面只能跟整型数字,如果是加法运算,后面只有是列表

in 和 not in
  • in用来检查指定元素是否在列表当中
  • not in 用来检查指定元素是否不在列表当中
>>> a = ['a', 'b', 'c', 'd', 'e', 'f']
>>> 'a' in a
True
>>> 1 in a
False
>>> 'b' not in a
False
>>> 

长度与最值

  • len() 获取列表中元素的个数
  • max() 获取列表中最大值
  • min() 获取列表中最小值
>>> a = ['a', 'b', 'c', 'd', 'e', 'f']
>>> len(a)
6
>>> max(a)
'f'
>>> min(a)
'a'
>>> 
  • list.index(x[, start[, end]])
    1.第一个参数 获取指定元素在列表中的位置
    2.第二个参数 表示查找的起始位置
    3.第三个参数 表示查找的结束位置
>>> a = ['a', 'b', 'c', 'd', 'e', 'f']
>>> a.index('e')
4
>>>#当列表中有相同的元素时,不指定范围,只能找第一个,指定范围可以找到其它的元素的索引
>>> (a*2).index('e')
4
>>> (a*2).index('e',5)
10
>>> 

如果列表中有相同的元素时,不指定范围,只能找第一个,指定范围可以找到其它的元素的索引

  • list.count(x) 统计指定元素在列表中出现的个数
>>> a = ['a', 'b', 'c', 'd', 'e', 'f']
>>> a.count('e')
1
>>> (a*2).count('e')
2
修改列表
  • 通过切片来修改(起始就是给切片的内容重新赋值,但是赋值的内容必须是一个序列)
>>> a[2:4] = "xy"
>>> a
['a', 'b', 'x', 'y', 'e', 'f']
>>> a[2:4] = 'x'
>>> a
['a', 'b', 'x', 'e', 'f']
>>> a[3] = 'y'
>>> a[2:4] = 'xyz'
>>> a
['a', 'b', 'x', 'y', 'z', 'e', 'f']
  • 当设置了步长时,序列中元素的个数必须和切片中元素的个数保持一致
>>> a[:5:2] = '123456'
Traceback (most recent call last):
  File "<pyshell#47>", line 1, in <module>
    a[:5:2] = '123456'
ValueError: attempt to assign sequence of size 6 to extended slice of size 3
>>> a[:5:2] = '123'
>>> a
['1', 'b', '2', 'y', '3', 'e', 'f']

通过切片来删除元素

  • del list[起始 : 结束]
  • list = []
>>> a = ['1', 'b', '2', 'y', '3', 'e', 'f']
>>> del a[2:4]
>>> a
['1', 'b', '3', 'e', 'f']

列表的方法

  • append() 像列表的最后添加一个元素
>>> a = ['1', 'b', '3', 'e', 'f']
>>> a.append('x')
>>> a
['1', 'b', '3', 'e', 'f', 'x']
  • insert(arg1,arg2) 像列表指定位置插入一个元素 参数1:要插入的位置 参数2:要插入的元素
>>> a = ['1', 'b', '3', 'e', 'f']
>>> a.insert(3,'x')
>>> a
['1', 'b', '3', 'x', 'e', 'f']
  • extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列
>>>a = [1,2,3,4,5,6]
>>> a.extend(a)
>>> a
[1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6]
  • pop() 根据索引删除并返回指定元素
>>> a = ['f', 'e', 'x', '3', 'b', '1']
>>> a.pop(2)
'x'
  • remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)
>>> a = ['f', 'e', '3', 'b', '1']
>>> a.remove('1')
>>> a
['f', 'e', '3', 'b']

注意:

  1. pop()和remove()两个方法共同点都是删除列表中的元素;
  2. pop()删除列表索引位置的值并返回删除的值,而remove()只删除对应的元素;
  3. pop()按索引删除元素,而remove()直接删除值。
  • reverse() 翻转列表
>>> a = ['1', 'b', '3', 'x', 'e', 'f']
>>> a.reverse()
>>> a
['f', 'e', 'x', '3', 'b', '1']
>>> 
  • sort(key=None,reverse=False) 用来对列表中的元素进行排序 reverse:True反序;False 正序
>>> a = [1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6]
>>> a.sort()
>>> a
[1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6]

注意:sort()是方法,而sorted()是函数,它们的作用是一样的,都是对列表排序的

>>> a = ['1', 'b', '3', 'x', 'e', 'f']
>>> sorted(a)
['1', '3', 'b', 'e', 'f', 'x']

for循环遍历

for循环

• 通过for循环来遍历列表

语法

for 变量 in 序列(遍历的规则):
代码块
• 注意: for循环的代码块会执行多次,序列中有几个元素就会执行几次。每执行一次就会将序列中的一个元素赋值给变量,所以我们可以通过变量来获取列表中的元素

for i in lst:
    pass

range(start, stop[, step])

参数说明
• ·start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
• stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
• step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)

>>> i = range(5)
>>> print(i)
range(0, 5)
>>> type(i)
<class 'range'>

range居然是一种类,我本以为是list


第六讲作业

1.现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程

a = [1,2,3,4,5,6]
print(a[::-1])
  • 运行结果:
[6, 5, 4, 3, 2, 1]

如果用函数完成,应使用reverse()方法。

2. 给用户9次机会猜1 - 10 个数字随机来猜数字。如果随机的数字和用户输入的数字一致则表示正确,如果不一致则表示错误。最终结果要求用户怎么也猜不对

print("在0到9十个数字当中猜一个数字,猜对有重奖,你有9次机会,快来试一试!")
lst = [i for i in range(10)]
for i in range(9):
    if i <= 7:
        x = eval(input("这是第{}次机会,输入你要猜的数字:\n".format(i+1)))
        lst.remove(x)
        print("抱歉,你猜错了,不要灰心,再来一次")
    else:
        x = eval(input("这是最后一次机会,输入你要猜的数字:\n"))
        lst.remove(x)
        print("真遗憾,你能猜错了,正确答案是{}".format(lst))
  • 运行结果:
在0到9十个数字当中猜一个数字,猜对有重奖,你有9次机会,快来试一试!
这是第1次机会,输入你要猜的数字:
0
抱歉,你猜错了,不要灰心,再来一次
这是第2次机会,输入你要猜的数字:
1
抱歉,你猜错了,不要灰心,再来一次
这是第3次机会,输入你要猜的数字:
2
抱歉,你猜错了,不要灰心,再来一次
这是第4次机会,输入你要猜的数字:
3
抱歉,你猜错了,不要灰心,再来一次
这是第5次机会,输入你要猜的数字:
4
抱歉,你猜错了,不要灰心,再来一次
这是第6次机会,输入你要猜的数字:
5
抱歉,你猜错了,不要灰心,再来一次
这是第7次机会,输入你要猜的数字:
6
抱歉,你猜错了,不要灰心,再来一次
这是第8次机会,输入你要猜的数字:
7
抱歉,你猜错了,不要灰心,再来一次
这是最后一次机会,输入你要猜的数字:
8
真遗憾,你能猜错了,正确答案是9

3.有两个列表 lst1 = [11, 22, 33],lst2 = [22, 33, 44],获取内容相同的元素

#方法1,遍历列表,取出相同元素
lst1 = [11, 22, 33]
lst2 = [22, 33, 44]
for i in lst1:
    if i in lst2:print(i,end = "\t")

#方法2,转化为集合求交集
print(set(lst1) & set(lst2))
  • 运行结果:
#方法1:
22  33  

#方法2
{33, 22}

4.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中

  • 思路分析:采用隔板法,在8位老师中间插入两个隔板,则8位老师被分为3份,每一份对应一个办公室,这样完成分配。
from random import randint

lst = ['赵','钱','孙','李','周','吴','郑','王']
lst1 = []
lst2 = []
lst3 = []

n = 7
while n >= 1:
    m = randint(0,n)
    if m % 3 == 1:
        lst1.append(lst.pop(m))
    elif m % 3 == 2:
        lst2.append(lst.pop(m))
    else:
        lst3.append(lst.pop(m))
    n -= 1
else:
    m = randint(1,3)
    if m % 3 == 1:
        lst1.append(lst.pop(0))
    elif m % 3 == 2:
        lst2.append(lst.pop(0))
    else:
        lst3.append(lst.pop(0))
print("第1间办公室分配的老师是{}\n第2间办公室分配的老师是{}\n\
第3间办公室分配的老师是{}\n".format(lst1,lst2,lst3))
  • 运行结果:
#第1次运行
第1间办公室分配的老师是['钱', '孙', '吴']
第2间办公室分配的老师是['郑', '李', '周']
第3间办公室分配的老师是['赵', '王']

#第二次运行
第1间办公室分配的老师是['王', '钱', '郑', '孙']
第2间办公室分配的老师是['李', '周', '吴', '赵']
第3间办公室分配的老师是[]

#第三次运行
第1间办公室分配的老师是['王']
第2间办公室分配的老师是['吴', '孙', '李', '周', '郑']
第3间办公室分配的老师是['赵', '钱']
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容