前言:
包括条件控制if – elif – else
、循环语句for
和while
、迭代器与生成器等内容的介绍与基本操作
条件控制 if – elif – else
if
Python中用elif
代替了else if
,所以if语句的关键字为:if – elif – else
1 | if condition_1: # 条件1:condition_1 |
- 每个条件后面要使用冒号
:
,表示接下来是满足条件后要执行的语句块 - 使用缩进来划分语句块,相同缩进数的语句在一起组成一个语句块
- 在Python中没有
switch – case
语句 - 条件为真:1,非零数值,True, 非空字符串,至少有一个元素的容器对象,非None对象 条件为假:0,0.0, False, ‘’(空字符串),[],(),{},set(),None
if嵌套
在嵌套if
语句中,可以把if...elif...else
结构放在另外一个if...elif...else
结构中1
2
3
4
5
6
7
8
9
10
11num=int(input("输入一个数字:"))
if num%2==0:
if num%3==0:
print ("你输入的数字可以整除 2 和 3")
else:
print ("你输入的数字可以整除 2,但不能整除 3")
else:
if num%3==0:
print ("你输入的数字可以整除 3,但不能整除 2")
else:
print ("你输入的数字不能整除 2 和 3")
输出结果:
1 | $ python3 test.py |
循环语句 for 和 while
Python中的循环语句有for
和while
while语句
(1)基本用法:计算 1 到 100 的总和(5050):
1 | n,sum,counter = 100,0,1 |
(2)while 循环使用 else 语句:
在while … else
在条件语句为false
时执行else
的语句块:
1 | count = 0 |
for语句
(1)for
循环可以遍历任何序列的项目,如一个列表或者一个字符串,for循环的一般格式如下:
1 | for <variable> in <sequence>: |
(2)for
实例中可以使用break
语句,break
语句用于跳出当前循环体:
1 | sites = ["Baidu", "Google","Runoob","Taobao"] |
输出结果:
1 | 循环数据 Baidu |
range()函数
(1)如果需要遍历数字序列,可以使用内置range()
函数,它会生成数列:
1 | for i in range(5): |
(2)range指定区间的值:
1 | for i in range(5,9) : |
(3)range
以指定数字开始并指定不同的增量(甚至可以是负数,有时这也叫做’步长’):
1 | for i in range(0,10,3) : |
(4)结合range()
和len()
函数以遍历一个序列的索引,如下所示:
1 | a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ'] |
break 和 continue 语句及循环中的 else 子句
(1)break
语句可以跳出for
和while
的循环体。如果你从for
或while
循环中终止,任何对应的循环else
块将不执行
1 | n = 5 |
(2) continue 语句被用来告诉Python跳过当前循环块中的剩余语句,然后继续进行下一轮循环
1 | n = 5 |
循环语句可以有
else
子句,它在穷尽列表(以for循环)或条件变为false
(以while循环)导致循环终止时被执行,但循环被break
终止时不执行
(3)冒泡排序:
1 | def maopao_sort(li): |
pass 语句
(1) pass
是空语句,是为了保持程序结构的完整性,pass
不做任何事情,一般用做占位语句
1 | for letter in 'Runoob': |
迭代器
(1)迭代是Python最强大的功能之一,是访问集合元素的一种方式,迭代器是一个可以记住遍历的位置的对象
(2)迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束,迭代器只能往前不会后退
(3)迭代器有两个基本的方法:iter()
和next()
,字符串,列表或元组对象都可用于创建迭代器
1 | list=[1,2,3,4] |
创建迭代器
(1)把一个类作为一个迭代器使用需要在类中实现两个方法__iter__()
与__next__()
(2)__iter__()
方法返回一个特殊的迭代器对象, 这个迭代器对象实现了__next__()
方法并通过StopIteration
异常标识迭代的完成
(3)__next__()
方法(Python 2 里是next()
)会返回下一个迭代器对象
1 | class MyNumbers: # 创建一个返回数字的迭代器,初始值为 1,逐步递增 3 |
输出结果:
1 | 第 0 次迭代值为: 1 |
StopIteration
(1)StopIteration
异常用于标识迭代的完成,防止出现无限循环的情况,在__next__()
方法中我们可以设置在完成指定循环次数后触发StopIteration
异常来结束迭代
1 | class MyNumbers: # 创建一个返回数字的迭代器,初始值为 1,逐步递增 3, 4次迭代后停止执行 |
生成器
(1)使用了yield
的函数被称为生成器generator
(2)跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器
(3)在调用生成器运行的过程中,每次遇到yield
时函数会暂停并保存当前所有的运行信息,返回yield
的值, 并在下一次执行next()
方法时从当前位置继续运行
(4)调用一个生成器函数,返回的是一个迭代器对象,如下斐波那契数列打印使用和不使用yield
进行比较
使用yield:
1 | import sys |
输出结果:
1 | 0 a = 0 | a = 1 b = 1 |
不使用yield:
1 | import sys |
输出结果:
1 | a = 0 | a = 1 b = 1 |
(5)yield使用场景:
一个函数fab
,fab
返回一个list
,这个list
是动态计算出来的,并且这个list
会很大(无论是固定很大还是随着输入参数的增大而增大),这个时候,我们希望每次调用这个函数并使用迭代器进行循环的时候一个一个的得到每个list
元素而不是直接得到一个完整的list
来节省内存,这个时候yield
就很有用
以斐波那契函数为例,我们一般希望从n
返回一个n
个数的list
1 | def fab(max): # 简单输出斐波那契数列前 max 个数 |
fab
函数从参数max
返回一个有max
个元素的list
,当这个max
很大的时候,会非常的占用内存
如果使用list
的迭代器。那么我们可以让这个函数fab
每次只返回一个迭代器(一个计算结果),而不是一个完整的list
,运行方式是每次的调用都在yield
处中断并返回一个结果,然后再次调用的时候再恢复中断继续运行:
1 | def fab(max): # 简单输出斐波那契数列前 max 个数 |