Python分支结构与流程控制
Python分支结构与流程控制
分支结构
if 语句
分支结构在任何编程语言中都是至关重要的一环,它最主要的目的是让计算机拥有像人一样的思想,能在不同的情况下做出不同的应对方案,所以if
语句不管是在什么时候都是会大量去使用的。我们先来看一下if
语句的语法和使用。
# ==== if 的使用 ====
'''
if 条件判断:
逻辑代码...
if 条件判断:
逻辑代码...
if 条件判断:
逻辑代码...
'''
tag = 1
if tag == 1:
print("判断为真,tag = 1")
if tag == 2:
print("判断为真,tag = 2")
if tag:
print('判断为真,tag为True')
if not tag:
print('判断为真,tag为False')
print('执行完毕...')
# ==== 执行结果 ====
"""
判断为真,tag = 1
判断为真,tag为True
执行完毕...
"""
可以看到,上面一共有4条if
判断,对应的逻辑代码也共有4段(4个print()
),从语法层面上来讲Python中只要遇到以冒号 :
结尾的语句下一行必须缩进4个空格。(PEP8
规范中并不推荐使用tab),在4个空格后的代码便是上面一个冒号的子代码段。
这里只执行了2个逻辑子代码,说明if
只在条件为真的情况下执行它自己的子代码段。我们继续来看一个实例分析:
# ==== if 实例分析 ====
'''
二狗子要找女朋友,
年龄不能大于25岁,这个是前提!!,
身高不能超过170或者体重不能超过60公斤。
请问下面那个符合二狗子的需求?
'''
xiaoli = {'age':30,'height':158,'weight':90}
xiaohua = {'age':22,'height':190,'weight':50} #从上一章中过来的读者注意,age改为22了。
xiaocui = {'age':22,'height':164,'weight':58}
# 使用括号,改变优先级。不然会出现bug
if xiaoli['age']<25 and (xiaoli['height']<170 or xiaoli['weight']<60):
print("小丽符合二狗子的要求..小丽和二狗子约会了")
if xiaohua['age']<25 and (xiaohua['height']<170 or xiaohua['weight']<60):
print("小花符合二狗子的要求..小花和二狗子约会了")
if xiaocui['age']<25 and (xiaocui['height']<170 or xiaocui['weight']<60):
print("小翠符合二狗子的要求..小翠和二狗子约会了")
print("执行完毕...")
# ==== 执行结果 ====
"""
小花符合二狗子的要求..小花和二狗子约会了
小翠符合二狗子的要求..小翠和二狗子约会了
执行完毕...
"""
if 实例分析
二狗子的做法令二狗子的父母很不满意,他们认为如果和一个姑娘约了会就不该再和其他姑娘继续约会。这是道德问题,如果让女孩子知道了这些事儿,二狗子就会落下一个不好的名声,所以二狗子的父母希望二狗子不要这么做。那么该如何解决呢?
if 与 else
上面遗留问题的我们先来分析一下,只有当二狗子和某一个女孩约会那个女孩不符合二狗子的要求时二狗子才能继续和下一个女孩进行约会,这其中有一个 如果怎么,否则怎样的关系在里面。那么就可以用到if
和else
的配套使用来解决这个问题,if代表是如果条件成立则执行if
语句下的子代码块,而else
代表if
条件不成立则执行else
语句下的子代码块。所以if
和else
是配套使用的,在同一缩进范畴下的if
和else
认为是一对。还是先看一下if
和else
的使用方法,再来解决具体问题:
# ==== if 与 else 的使用 ====
'''
if 条件判断:
逻辑代码...
else:
逻辑代码...
'''
tag = 2 # 注意tag改成了2
if tag == 1:
print("判断为真,tag = 1")
else:
print("判断为假,tag != 1")
if tag:
print('判断为真,tag为True')
else:
print('判断为假,tag为False')
print('执行完毕...')
# ==== 执行结果 ====
"""
判断为假,tag != 1
判断为真,tag为True
执行完毕...
"""
好了,简单的学习了 if
和 else
的使用后我们来解决二狗子爸妈的疑虑。
# ==== if 与 else 实例分析 ====
'''
二狗子要找女朋友,
年龄不能大于25岁,这个是前提!!,
身高不能超过170或者体重不能超过60公斤。
请问下面那个符合二狗子的需求?
'''
xiaoli = {'age':30,'height':158,'weight':90}
xiaohua = {'age':22,'height':190,'weight':50} #从上一章中过来的读者注意,age改为22了。
xiaocui = {'age':22,'height':164,'weight':58}
# 使用括号,改变优先级。不然会出现bug
if xiaoli['age']<25 and (xiaoli['height']<170 or xiaoli['weight']<60):
print("小丽符合二狗子的要求..小丽和二狗子约会了")
else:
print("由于小丽不符合二狗子的要求,二狗子决定和小花约会试试..")
if xiaohua['age']<25 and (xiaohua['height']<170 or xiaohua['weight']<60):
print("小花符合二狗子的要求..小花和二狗子约会了")
else:
print("由于小花不符合二狗子的要求,二狗子决定和小翠约会试试..")
if xiaocui['age']<25 and (xiaocui['height']<170 or xiaocui['weight']<60):
print("小翠符合二狗子的要求..小翠和二狗子约会了")
else:
print("所有的女孩子都不符合二狗子的要求,二狗子决定单身一辈子")
print("执行完毕...")
# ==== 执行结果 ====
"""
由于小丽不符合二狗子的要求,二狗子决定和小花约会试试..
小花符合二狗子的要求..小花和二狗子约会了
执行完毕...
"""
if 与 else 实例分析
可以看到二狗子在约会成功后就没有继续再做约会了,完成了二狗子爸妈的需求。但是这段代码看起来实在是太糟糕了,如果有100个女孩和二狗子约会这样一直写 if
和 else
那么到最后岂不是一直往右边飘到天上去了吗?所以我们需要一个在保证这种逻辑判断下并且提高代码可读性的解决方案。
if 与 elif 以及 else
为了解决单纯的if
和else
嵌套带来的阅读性差的问题。这里出现了elif
这个东西,它相当于是else
和if
的缩写版,我们来看一下他的使用方法:
# ==== if 与 elif 的使用 ====
'''
if 条件判断:
逻辑代码...
elif 条件判断: #如果条件成立,剩下同级别下的elif与else都不将再继续执行。
逻辑代码...
elif 条件判断:
逻辑代码...
else:
逻辑代码
'''
tag = 2 # 注意 tag 改成了2
if tag == 1:
print("判断为真,tag = 1")
elif tag == 2:
print("判断为真,tag == 2")
elif tag == 3:
print("判断为真,tag == 3")
else:
print("判断为假,tag既不等于1也不等于2或者3")
print('执行完毕...')
# ==== 执行结果 ====
"""
判断为真,tag == 2
执行完毕...
"""
elif
只会执行一个。剩下的elif
或者else
便会直接跳过,(如果elif
下面有if
语句,还是会执行if
语句的)
二狗子找女朋友改进版:
# ==== if 与 elif 以及else 实例分析 ====
'''
二狗子要找女朋友,
年龄不能大于25岁,这个是前提!!,
身高不能超过170或者体重不能超过60公斤。
请问下面那个符合二狗子的需求?
'''
xiaoli = {'age':30,'height':158,'weight':90}
xiaohua = {'age':22,'height':190,'weight':50} #从上一章中过来的读者注意,age改为22了。
xiaocui = {'age':22,'height':164,'weight':58}
# 使用括号,改变优先级。不然会出现bug
if xiaoli['age']<25 and (xiaoli['height']<170 or xiaoli['weight']<60): #if 和 elif 中不能夹杂 print()。所以没办法及时告诉二狗子的父母二狗子本次的情况,只有全部结束后else中才会告诉二狗子的父母。
print("小丽符合二狗子的要求..小丽和二狗子约会了")
elif xiaohua['age']<25 and (xiaohua['height']<170 or xiaohua['weight']<60):
print("小花符合二狗子的要求..小花和二狗子约会了")
elif xiaocui['age']<25 and (xiaocui['height']<170 or xiaocui['weight']<60):
print("小翠符合二狗子的要求..小翠和二狗子约会了")
else:
print("所有的女孩子都不符合二狗子的要求,二狗子决定单身一辈子")
print("执行完毕...")
# ==== 执行结果 ====
"""
小花符合二狗子的要求..小花和二狗子约会了
执行完毕...
"""
可以看到。当3个语句都有的时候,它的构成是这样的:
if
开头,elif
夹杂中间,else
放在尾部。if
代表开始执行逻辑判断与判断第一条语句,如果第一条语句不成立则判断所有的elif
语句,一旦有一条elif
语句判断成功则直接跳过接下来同级的elif
与else
。当if
与所有的elif
都不成立时才执行else
。
流程控制之条件循环
条件循环 while
结构分支让计算机像人一样能够应对不同的情况而做出不同的对应方案,那么循环就是让计算机具有重复做一件事的能力。
while
循环也是很多编程语言中都存在的,它的使用也非常广泛,while
循环是一种基于条件的循环。当条件为真时开始重复执行子代码块中的内容直至条件为假后跳出循环。我们来看一下while
循环的语法与简单使用:
# ==== while循环的使用 ====
tag = 10
while tag > 5:
print("tag的数值目前是:{num}".format(num=tag))
tag -= 1
print('while循环执行完毕')
print(tag)
# ==== 执行结果 ====
"""
tag的数值目前是:10
tag的数值目前是:9
tag的数值目前是:8
tag的数值目前是:7
tag的数值目前是:6
while循环执行完毕
5
"""
做一个小案例,来更加清晰的了解while循环的使用:
# ==== while循环 实例分析 ====
'''
小王和小张在打架,小王很愤怒,一旦怒气值达到了100小王就会化身斯巴达...
'''
import random # 生成随机数的一个模块。
anger = 10 #小张骂了小王2句,小王目前怒气值为10...
while anger != 100:
mode = random.randrange(0,3) # 有 0,1,2三个随机数
if mode == 0:
print("小张对小王破口大骂,小王怒气值加5")
anger += 5
elif mode == 1:
print("小张使劲打了小王一拳!小王怒气值加10")
anger += 10
else:
print("小张用尽浑身力气踹了小王一脚,小王怒气值加20")
anger += 20
print("="*30)
print("小王目前怒气值:{}".format(anger))
print("小王化身斯巴达,一屁股坐死了小张...")
print("="*30)
# ==== 执行结果 ====
'''
小张使劲打了小王一拳!小王怒气值加10
小张对小王破口大骂,小王怒气值加5
小张对小王破口大骂,小王怒气值加5
小张用尽浑身力气踹了小王一脚,小王怒气值加20
小张用尽浑身力气踹了小王一脚,小王怒气值加20
小张用尽浑身力气踹了小王一脚,小王怒气值加20
小张使劲打了小王一拳!小王怒气值加10
==============================
小王目前怒气值:100
小王化身斯巴达,一屁股坐死了小张...
==============================
'''
while循环 实例分析
可以看到while在某些情况下应用是非常有效的,比如银行取钱,游戏开箱等等。
银行取钱:
有一个变量存储当前输入密码的次数
当变量变为0或者密码输入正确后跳出循环,否则就一直提示需要输入密码,当前输入错误的次数以及剩下的次数等等
游戏开箱:
有一个变量存储当前剩余宝箱的数量
当变量为0时退出循环,并且循环中一定存有随机函数掉落随机的物品
我们来模仿一下银行取钱的程序:
# ==== 银行取钱 ====
money = "" # 用str类型,可以不用再做input输入后的转换。
count = 5
username = "yunya"
passwd = "" # 用str类型,可以不用再做input输入后的转换。
while count:
print("您总共可输入{0}次密码,当前还剩余{1}次输入机会".format(5,count))
username_input = input("请输入用户名\n>>>")
passwd_input = input("请输入密码\n>>>")
if username == username_input and passwd == passwd_input:
select = input('您好,{0}!\n您当前账户余额为:{1},请选择您的操作方式:\n1.取款\n2.退出\n>>>'.format(username,money))
if select == "":
num = input('请输入取款金额:')
if num > money:
print("您的余额不足,取款失败")
count = 0
else:
print("取款成功")
count = 0
else:
print("正在退出...请稍候")
count = 0
else:
count -= 1
print("期待您的下次光临")
银行取钱
基于条件的退出
面已经介绍过while
本身是基于条件的循环。如果条件为False
时则不再继续执行while
循环体内的代码,从上面3个程序的演示就已经看得出来了。那为什么还要单独拿出来讲呢?因为基于条件的退出就算条件被改变也一定会执行接下来的while
循环体中的代码。我们来看一看:
# ==== 基于条件的退出 ====
count = 5
while count != 10:
count = 10 #修改条件后。不会立刻退出
print("当前count的数值为:",count)
print("----> 执行中")
print("执行完毕..")
# ==== 执行结果 ====
"""
当前count的数值为: 10
----> 执行中
执行完毕..
"""
while 与 break
break
代表立马结束本层循环。不会执行当前break
后的代码。
# ==== while 与 break ====
count = 5
while count != 10:
break #立刻退出
print("当前count的数值为:",count)
print("----> 执行中")
print("执行完毕..")
# ==== 执行结果 ====
"""
执行完毕..
"""
while 与 continue
continue
代表跳出本次循环。执行下一次循环。
# ==== while 与 continue ==== count = 5
while count != 10:
if count == 8:
count += 1 #必须放在前面。不然会产生死循环
continue
print(count) #不会执行countinue后的代码。
print(count)
count += 1
print("执行完毕..")
# ==== 执行结果 ====
"""
5
6
7
9
执行完毕..
"""
while 与 else
else
是非常装逼的一个玩法(个人感觉),因为与else
搭配最多的是if
语句。所以与while
搭配的else
一般不会太常用。
while
与else
的搭配中,只要while
循环不是由break
跳出的就在循环完成后执行else
子代码块。
# ==== while 与 else ====
# 正常退出while循环。紧接着执行else子代码块
tag = 1
while tag < 5:
print(tag)
tag += 1
else:
print("else代码块:\n tag --> ",tag)
print("执行完毕..")
# ==== 执行结果 ====
"""
1
2
3
4
else代码块:
tag --> 5
执行完毕..
"""
while 循环嵌套
while
循环中允许多层嵌套。当在多层嵌套的while
循环中有以下几点需要注意:
1.如果是使用 基于条件退出 那么所有的
while
循环都必须遵循同一个条件才能退出。2.
break
只针对当前的while循环体退出,对于非当前的while
循环体不生效。3.
continue
只针对当前while循环体跳过,对于非当前的while
循环体不生效。
# ==== 多层while循环基于条件退出注意事项 ====
# 错误示范
tag1 = 1
tag2 = 2
while tag1 == 1:
print("一层..")
while tag2 == 2:
print(" 二层..")
while tag2 == 2:
print(" 三层..")
tag2 = 3 #由于条件不同。只退出 第二层和第三层。
# ==== 执行结果 ====
"""
一层..
二层..
三层..
一层..
一层..
一层..
(无限打印)
"""
# ==============================================手动分割线==============================================
#正确示范
tag3 = 3
while tag3:
print("一层..")
while tag3:
print(" 二层..")
while tag3:
print(" 三层..")
tag3 = False # 可以看到全部退出了。
# ==== 执行结果 ====
"""
一层..
二层..
三层..
""" # ==== 多层while循环基于break退出注意事项 ====
# 错误示范
tag1 = 1
tag2 = 2
while tag1 == 1:
print("一层..")
while tag2 == 2:
print(" 二层..")
while tag2 == 2:
print(" 三层..")
break # 跳出三层。回到二层。执行三层。跳出三层。回到二层。执行三层。
# ==== 执行结果 ====
"""
一层..
二层..
三层..
二层..
三层..
二层..
三层..
(无限打印)
"""
# ==============================================手动分割线==============================================
# 正确示范
tag3 = 3
while tag3:
print("一层..")
while tag3:
print(" 二层..")
while tag3:
print(" 三层..")
break # 跳出三层
break # 跳出二层
break # 跳出一层
# ==== 执行结果 ====
"""
一层..
二层..
三层..
"""
多层while循环基于条件退出注意事项
那么现在的while
循环内容都学过了。我们针对银行取钱程序做一次优化升级,让它更符合逻辑(代码初学者必读):
# ==== 银行取钱程序终极版 ====
'''
银行取钱改进需求:
1.当输入密码正确后取款完成后不会再次要求输入密码
2.当输入密码正确后取款失败后也不会再次要求输入密码
3.针对使用 输入 2 退出的正常操作流程和输入密码错误超过上限被迫退出的流程做不同的回应
4.取款后总额扣除取款的相应金额
解决方案:
对于 1,2 来说都可以增加一层while循环。
对于 3 来说。正常退出不走else提示(基于break提示提出),被迫退出则走else(基于条件退出)
对于 4 来说。只需要做一次四则运算即可
'''
money = 100 # 有了真正的取钱,就用int类型。因为str没办法做减法
count = 5
username = "yunya"
passwd = "" # 用str类型,可以不用再做input输入后的转换。
select = None # 选择记录。
while count:
if select: # 如果是没有成功登陆过。这里就是None,通过break退出不会执行else。
break
print("您总共可输入{0}次密码,当前还剩余{1}次输入机会".format(5, count))
username_input = input("请输入用户名\n>>>")
passwd_input = input("请输入密码\n>>>")
if username == username_input and passwd == passwd_input:
while True:
select = input('您好,{0}!\n您当前账户余额为:{1},请选择您的操作方式:\n1.取款\n2.退出\n>>>'.format(username, money))
if select == "":
num = int(input('请输入取款金额:')) # 这里也接收为int类型
if num > money:
print("您的余额不足,取款失败")
else:
print("取款成功")
money = money - num
elif select == "":
print("正在退出...请稍候")
break
else:
count -= 1 # 如果是条件退出。则会执行else
else:
print('您的密码输入次数过多,系统已强制退出')
print("期待您的下次光临")
银行取钱程序终极版
死循环带来的性能损耗
死循环既永远跳不出的循环。
因为在计算机硬件基础中讲到,CPU
的运行速度是绝对会被I/O
操作所拖慢的(因为硬盘速度慢,内存速度也赶不上CPU
的处理速度)。所以当在while
死循环中使用I/O
操作的时候CPU
是有休息时间的,而一旦没有I/O
操作只是做单纯的计算操作CPU
的压力会无比巨大。所以在死循环中,千万要注意规避没有I/O
操作而只有单纯的计算操作这种傻逼行为。
# ==== 死循环带来的性能损耗 ====
x = 2
while 1: # 使用while 1 比while True 会带来微乎其微的性能提升(计算机内部都是二进制。如果用字符True会经历转换过程)
x **= 12 # SB行为,CPU不断的运算只会让它肾虚
#===============================================
while 1:
print("====") #这种死循环没事。因为CPU要调用显示器来显示,所以CPU会有休息时间
流程控制之取值循环
取值循环 for
Python中提供了while
循环,还提供了一种for
循环机制。(for
循环本身就是基于while
循环做出来,后面会讲到)。for
循环对于某些操作来说比while
循环更加省事省力,也是我们以后会经常使用的东西。
应用场景:取值,如list
,tuple
# ==== for 循环的使用 ====
'''
for 迭代变量 in 迭代器(或者认为可迭代对象,不深究)
逻辑操作... '''
li1 = [1,2,3,4,5,6,7]
for i in li1:
print(i)
# ==== 执行结果 ====
"""
1
2
3
4
5
6
7
"""
可以看到。i这个迭代变量拿到的正是列表中的具体元素(这点尤其重要,和其他的编程语言有点不一样,如JavaScript)。还记得集合吗?在介绍集合的时候没有详细说集合中的元素该怎么拿出来。是因为那时候没学for
循环,(集合没有key
,无法通过键值对取值,也没有index
,无法通过索引取值),那么集合的取值方法就是通过for
循环。
如果对字典进行for
循环,迭代变量保存的值是字典的key
,这点尤其要注意。
# ==== 对字典的 for 循环 ====
d1 = {"k1": "v1", "k2": "v2", "k3": "v3"}
for k in d1:
print(k)
print(d1[k]) # 可以使用该方法取出字典的 value
# ==== 执行结果 ====
"""
k1
v1
k2
v2
k3
v3
"""
如果对str
进行迭代,那么任何字符串子串(字符)都会被当拿出来。包括空格
# ==== 对 str 的 for 循环 ====
s1 = "- - - - - -"
for i in s1:
print(i) # ==== 执行结果 ====
"""
-
-
-
-
-
-
"""
for 循环的退出
for
循环的退出,一般是在迭代(或者称之为遍历)完整个被迭代对象后就自动退出了。一定要注意在这里讲的for
循环其实是比较浅层次的,关于深层次的for
循环会在后面讲到。关于for
循环的退出无法通过条件退出,因为他根本不是基于条件运行的。
for 与 break
for
循环中的break
与while
循环中的相同。但是使用的不是很多,对于for
循环来说我们使用最多的就是它取值的便捷性而已。
# ==== for 与 break ====
s1 = "ABCDEFGHIJKLMN"
for i in s1:
if i=="J":
break
else:
print(i) # ==== 执行结果 ====
"""
A
B
C
D
E
F
G
H
I
"""
for 与 continue
for
循环与continue
的操作与while
循环与continue
的操作也是一样的。(我也很少使用for
和continue
的组合)
# ==== for 与 continue ====
s1 = "ABCDEFGHIJKLMN"
for i in s1:
if i=="J":
continue
else:
print(i) # ==== 执行结果 ==== Ps:没有 J
"""
C
D
E
F
G
H
I
K
L
M
N
"""
for 与 else
同while
循环一样。break
跳出循环操作不会走else
子代码块,而只有正常结束循环的操作才会走else
子代码块(装逼玩法):
# ==== for 与 else ====
s1 = "ABCDEFGHIJKLMN"
for i in s1:
if i=="J":
break
else:
print(i)
else:
print("没有break走else")
print("如果break结束for循环就不走else")
# ==== 执行结果 ==== Ps:没有 J
"""
A
B
C
D
E
F
G
H
I
如果break结束for循环就不走else
"""
len()方法
上面已经说过,for
循环的正常结束是遍历完整个可迭代对象。那么换而言之也就取决于被迭代对象中的元素个数,如何查看for
循环中的元素个数?使用len()
方法查看。(len
即是length
的缩写,代表长度的意思。)
>>> li1 = [1,2,3,4,5,6,7]
>>> print(len(li1))
7
>>>
for 与 range()方法
下面再介绍一个新的方法:range()
方法,range()
方法可用于生成一个装满整形的列表。比如range(10)
则代表生成一个列表,元素为[0,1,2,3,4,5,6,7,8,9].(注意:不包含尾部,姑且认为生成的是列表。但在Python2中它的确生成的是列表)。所以我们可以通过range()
方法可以让for
循环做很多事。
# ==== for 与 range() 组合使用 ====
#打印 十次 hello,world
for i in range(10):
print("hello,world")
# ==== 执行结果 ====
"""
hello,world
hello,world
hello,world
hello,world
hello,world
hello,world
hello,world
hello,world
hello,world
hello,world
"""
可以通过与len()
方法的结合,拿到元素的index
。
# ==== for range() len() 的组合使用 ====
li1 = ["a", "b", "c",]
for i in range(len(li1)): # len返回的是一个数字。长度为3,rang则恰恰是 0,1,2 不取3.
print(i)
print(li1[i])
# ==== 执行结果 ====
"""
0
a
1
b
2
c
"""
for 循环嵌套
for
循环同样支持嵌套。外层执行1次,内层的for
循环要全部循环完成才回到外层执行第2次。
# ==== for 循环嵌套 ====
li1 = ["a", "b"]
li2 = range(2) # 0,1
for i in li1:
print("============")
print("外层循环")
print(i)
for j in li2:
print(" 内层循环")
print(" ",j)
# ==== 执行结果 ====
"""
============
外层循环
a
内层循环
0
内层循环
1
============
外层循环
b
内层循环
0
内层循环
1
"""
range() 方法详解
Python2中的range()与xrange()
Python2中有range()
和xrange()
两种方法。xrange()
和Python3中的range()
是一模一样的。这个待会再介绍,我们先来看看range()
有哪些参数。注意:以下操作均是使用Python2中的range()
进行示例:
range()参数有3,分别代表开始
start
,结束stop
,步长step
。
start
- 由于
range()
生成的是一个包含整形的列表(Python2range()
),所以列表的第一个元素就是开始。默认是0
stop
- 列表的最后一个元素 ,必须手动填写。
step
- 步长代表跨几个拿一次元素,如果步长是2则代表从开始的数字数起来,每次数到2则加一个元素进列表。开始是0,向后数到2加进列表,数到4再加进列表。步长默认初始值为1。
# 如果要使用 步长 。则必须填入3个参数,否则会认为 第一个参数是开始,第二个参数是步长。
>>> range(1,10,2)
[1, 3, 5, 7, 9]
>>>
range()
生成的是一个列表,而xrange()
或者说Python3中的range()
生成的不是一个列表,而是一个经过优化的可迭代对象(对其调用循环时创建一个专属迭代器)。为什么要这么做呢?其实这一节的详细内容应该在学习过迭代器和生成器后再开始讲的。这里提一嘴:xrange()
和Python3的range()
创建的可迭代对象中并不存储具体的值,故称为经过优化的可迭代对象。当for
循环对其遍历时首先创建专属迭代器,再执行其__next__
方法。在该方法中通过一些计算手法能够做到和生成器相同的效果(xrange()
和Python3中的range()
创建出的迭代器也不属于生成器范畴)。换句话说,你创建xrange()
对象时不论其中有多少数值都不会占据非常大的内存空间,并且你可以多次循环遍历xrange()
对象。故很多教程中对xrange()
和Python3中的range()
解释为返回一个生成器。这是不准确的。
>>> type(xrange(10000000)) #xrange()的参数和使用都与range()相同。不同的是生成值的
<type 'xrange'>
>>> type(range(10))
<type 'list'>
>>>
Python3中的range()
Python3的range()
和Python2的xrange()
是一模一样的。Python3中没有xrange()
。如何将一个range()
这一个经过优化的可迭代对象转换为一个列表呢?
通过:list
(经过优化的可迭代对象名) 即可完成转换。
>>> # === 如何转换一个经过优化的可迭代对象为列表 ====
>>>
>>> type(range(10))
<class 'range'>
>>> range(10)
range(0, 10)
>>> list(range(10))
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>>
测试:使用for
循环嵌套与range()
函数写出一个 9 * 9 乘法表:
# ==== 9 * 9 乘法表 ====
for i in range(1,10):
for j in range(1,i+1):
print("{0}*{1}={2}".format(i,j,(i*j)),end=" | ") #内层的循环每一次不换行而作为一排。
print(" ") #占行使用。多层循环特性。外层循环一层内层全部循环完 # ==== 执行结果 ====
"""
1*1=1 |
2*1=2 | 2*2=4 |
3*1=3 | 3*2=6 | 3*3=9 |
4*1=4 | 4*2=8 | 4*3=12 | 4*4=16 |
5*1=5 | 5*2=10 | 5*3=15 | 5*4=20 | 5*5=25 |
6*1=6 | 6*2=12 | 6*3=18 | 6*4=24 | 6*5=30 | 6*6=36 |
7*1=7 | 7*2=14 | 7*3=21 | 7*4=28 | 7*5=35 | 7*6=42 | 7*7=49 |
8*1=8 | 8*2=16 | 8*3=24 | 8*4=32 | 8*5=40 | 8*6=48 | 8*7=56 | 8*8=64 |
9*1=9 | 9*2=18 | 9*3=27 | 9*4=36 | 9*5=45 | 9*6=54 | 9*7=63 | 9*8=72 | 9*9=81 |
"""
9 * 9 乘法表
Python分支结构与流程控制的更多相关文章
- python语法入门之流程控制
python语法入门之流程控制 流程控制是指控制流程,具体指控制程序执行的流程. 流程控制分为三种: 1.顺序结构 程序从上而下的正常执行(正常执行的代码就是顺序结构) 2.分支结构 赋予程序人的思维 ...
- Python第四天 流程控制 if else条件判断 for循环 while循环
Python第四天 流程控制 if else条件判断 for循环 while循环 目录 Pycharm使用技巧(转载) Python第一天 安装 shell 文件 Python第二天 ...
- 053 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 15 流程控制知识总结
053 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 15 流程控制知识总结 本文知识点: 流程控制知识总结 流程控制知识总结 选择结构语句 循环结构语句 ...
- 034 01 Android 零基础入门 01 Java基础语法 04 Java流程控制之选择结构 01 流程控制概述
034 01 Android 零基础入门 01 Java基础语法 04 Java流程控制之选择结构 01 流程控制概述 本文知识点:Java中的流程控制相关概念的认识 三大流程控制语句结构的简介 顺序 ...
- python分支结构与循环结构
python分支结构 一.if 单条件形式 # 年轻人的世界都不容易 age > 18 age = int(input("请输入您的年龄:")) # input()函数 模拟 ...
- 【Python】Java程序员学习Python(六)— 流程控制、异常处理
和Java语言一样,Python也有基本的流程控制,简单了解下即可. 一.流程控制的元素 条件 条件就是布尔值或者布尔值的表达式,要么是True要么是False. 代码块 在Python中,代码块不是 ...
- Python学习笔记 - day4 - 流程控制
Python流程控制 Python中的流程控制主要包含两部分:条件判断和循环. Python的缩进和语法 为什么要在这里说缩进和语法,是因为将要学习的条件判断和分支将会涉及到多行代码,在java.c等 ...
- Python开发【第3节】【Python分支结构与循环结构】
1.流程控制 流程: 计算机执行代码的顺序就是流程 流程控制: 对计算机代码执行顺序的管理就是流程控制 流程分类: 流程控制共分为3类: 顺序结构 分支结构/选择结构 循环结构 2.分支结构(if. ...
- Python第四章-流程控制
流程控制 在以前的代码中,所有的代码都是交由 Python 忠实地从头执行到结束.但是这些远远不够.很多时候需要根据不同的情况执行不同的代码. 如果你想改变这一工作流程,应该怎么做? 就像这样的情况: ...
随机推荐
- 公有继承中派生类Student对基类Person成员的访问 代码参考
#include <iostream> #include <cstring> using namespace std; class Person { private: char ...
- JVM系列.JDK演进历史
Java程序员为什么要了解虚拟机相关的知识 Java程序在设计之初就号称"一次编译,到处运行".Java之所以能做到"一次编译,处处运行"是因为Java虚拟机隐 ...
- vue-cli4 + TS构建新项目
1. 如果你之前没有安装vue-cli,可以通过如下命令进行安装: npm install -g @vue/cli yarn global add @vue/cli 2. 创建vue项目 vue cr ...
- Rocket - debug - Periphery
https://mp.weixin.qq.com/s/uGxn-Xec0LkwdaSsCtQBvw 简单介绍Periphery的实现. 1. ExportDebugDMI/ExportDebugJTA ...
- Chisel3 - 使用chisel-iotesters进行验证
https://mp.weixin.qq.com/s/KqyklKrPLtPm38sftMYlHA 1. 使用Maven获取库 Chisel相关的库基本上都可以使用Maven获取到(https ...
- Java实现 LeetCode 449 序列化和反序列化二叉搜索树
449. 序列化和反序列化二叉搜索树 序列化是将数据结构或对象转换为一系列位的过程,以便它可以存储在文件或内存缓冲区中,或通过网络连接链路传输,以便稍后在同一个或另一个计算机环境中重建. 设计一个算法 ...
- Java实现 LeetCode 448 找到所有数组中消失的数字
448. 找到所有数组中消失的数字 给定一个范围在 1 ≤ a[i] ≤ n ( n = 数组大小 ) 的 整型数组,数组中的元素一些出现了两次,另一些只出现一次. 找到所有在 [1, n] 范围之间 ...
- Java实现 蓝桥杯 历届试题 核桃的数量
历届试题 核桃的数量 时间限制:1.0s 内存限制:256.0MB 问题描述 小张是软件项目经理,他带领3个开发组.工期紧,今天都在加班呢.为鼓舞士气,小张打算给每个组发一袋核桃(据传言能补脑).他的 ...
- react后台管理系统路由方案及react-router原理解析
最近做了一个后台管理系统主体框架是基于React进行开发的,因此系统的路由管理,选用了react-router(4.3.1)插件进行路由页面的管理配置. 实现原理剖析 1.hash的方式 ...
- Web应用中解决问题的方案步骤?
我们学一个东西,通常两个目的: - 为了解决现有的问题 - 为了解决将来可能会有的问题 所以,在学这些东西之前,先必须了解,它们是用来解决什么问题的. 在Web应用中,我们需要解决的问题可以归纳为三类 ...