目录
今日内容总结
一、while循环内容补充
1、死循环
通过昨天的学习我们知道了当while的判断条件一直符合的情况下,我们会进入死循环,当程序的运算量比较小的时候,我们并没有什么感觉,只是需要手动结束代码的运行,但是当内部的运算变复杂或是内部的数据值变得很大的时候,内存和cpu的资源会被快速被占用,如果没有提前发现并结束代码的运行,计算机就会死机,之后需要重启才能使用。现在大家用的都是笔记本,可以在死循环运行的时候明显感受到cpu在燃烧,如果把这个死循环放到服务器中,可能会出现服务器着火爆炸之类的事。
# 这里举两个例子,把数据值变的很大的死循环。
# 1、使用乘法(*),出现较慢增长的死循环。这里可能效果会不明显,可以通过更改倍数或是多开几个程序同时运行来达成目标——死机。
count_test = 10
while True:
count_test *= 2
# 2、使用乘方(**),出现数据增长较快的死循环,简称死得快。
count_test = 10
while True:
count_test **= 2
2、嵌套和全局标志位
嵌套
#依旧是上面的例子,增加一些功能
#先输入拥有的钱的数量
a = int(input('请输入数字'))
#这里就进行判断了
while a > 500:
#大于500就去玩
print('我们想去哪就去哪')
a -= 100
while a > 1000:
#如果大于1000就连着玩直到少于500
a -= 200
print('我们有很多钱,还能再爽一次')
else:
print('没钱什么都做不了')
ps:嵌套出现的时候,只需要把对应从属关系的循环结构或是分支结构放在一起,并把他们一块块分割开研究,就可以比较清晰的得到运行顺序。
全局标志位
嵌套使用while语句的时候,while语句的判断处的判断条件都可以通过绑定变量名的方式,在满足条件时快速结束循环,而使用break时需要频繁插入break来达成结束循环的操作。代码展示在:三、break和continue的生效范围
二、循环结构之for循环
概念介绍
for循环也是循环结构的一种,但是和while不同的是,for循环并不会出现死循环,因此我们今后的使用中for会比较常见。
for循环的功能就是把一个对象中的所有数据一个个提取出来。而这个一个个提取数据的过程叫做遍历。
for循环结构:
for 变量名 in 需要遍历的对象:
表达式
可以遍历的数据类型:所有可以索引取值的数据类型(字符串、列表、元组、集合)和字典的k值。
for循环中的变量名也要尽量做到见名知意,如果感觉有困难,可以用一些常见的字母或者单词表示。
1、for结构
for 变量名 in 需要遍历的对象:
表达式
2、for...else结构
for 变量名 in 需要遍历的对象:
表达式
else:
表达式
这里的else结构和while结构下的else结构一样,都是在不能进入循环后执行一次,并不会跟着循环。
三、break和continue的生效范围
在昨天我们学习了break和continue的用法,但是昨天并没有出现很复杂的嵌套情况,而break和continue都是有生效范围的,并不能一次性结束所有的循环语句或是一次性跳到最外层的循环处。下面通过代码来具体说明:
# break和continue的生效范围是一样的
# 这里偷老师上课的代码举例,我一下想不出这么多循环的例子
# 这是一个登陆程序,这里用的事全局标志位
is_flag = True
while is_flag:
# 这里输入用户名和密码
username = input('username>>>:')
password = input('password>>>:')
if username == 'jason' and password == '123':
# 登陆成功后选择需要执行的指令,如果是‘q’就停止循环
while is_flag:
cmd = input('请输入您的指令>>>:')
if cmd == 'q':
is_flag = False
print('正在执行您的指令:%s' % cmd)
else:
print('用户名或密码错误')
# 这里用的是break方法
is_flag = True
while True:
# 这里输入用户名和密码
username = input('username>>>:')
password = input('password>>>:')
if username == 'jason' and password == '123':
# 登陆成功后选择需要执行的指令,如果是‘q’就停止循环
while True:
cmd = input('请输入您的指令>>>:')
if cmd == 'q':
break
print('正在执行您的指令:%s' % cmd)
break
else:
print('用户名或密码错误')
这里我们可以明显看到运行的时候,使用全局标志位只需要更改一下变量就能停止循环,但是使用break方法的时候需要连续的插入break,如果循环太多,很容易把人绕迷糊。
四、range方法
1、介绍
range方法起一个把输入的范围内,所有的整数都放到一个列表中的作用。但是range方法顾头不顾尾,最后的结尾不取。
2、不同版本中range方法的区别:
python2:
分为range和xrange两种
其中range就是把数据直接生成一个列表并把所有的数据值放进列表中。
而xrange就是在内存中生成一个类似工厂的东西,平时不会占用很大空间,当代码运行的时候需要用到xrange生成的列表的时候,才会开始工作,相对range节省内存空间。
python3:
python3中只有range这一种表达方式,但是作用是和python2中的xrange一样的。
通常来说有三种表达方式:
1、range(数值)
for i in range(100):
print(i)
# 这里就是打印从0开始,到99为止的100个数字
2、range(起始数值,结束数值)
for i in range(10,100):
print(i)
# 这里就是打印从10开始,到99为止的数字
3、range(起始数值,结束数值,间隔数值)
for i in range(10,100,2):
print(i)
# 这里就是打印从10开始,到99为止的数字,但是每隔两个数字打印一次。
3、实际应用:
主要应用在爬虫领域中,代码的世界中都是比较有规律可循的,所以range方法会大大方便我们查找。
举例:
在一些普通的网页中,我们可以发现网址是有规律的,我们这样通过这种方式,在数据值很多的时候获得所有的网址。
# 这里是博客园的不同页面的网址,我们可以找到规律就是自增1,而第一个没有显示p1。
但是我们可以大胆的去试试在网址后加上p1会不会跳到第一页去,毕竟代码都是有很强的逻辑性的,结果确实是可行的。
https://www.cnblogs.com/
https://www.cnblogs.com/#p2
https://www.cnblogs.com/#p3
https://www.cnblogs.com/#p4
但是也不是所有的网页都可以用这种方法获取,有一些网页会使用js文件产生动态编码的表达方式。
五、作业
1.计算1-100所有的数之和
# 1.计算1-100所有的数之和
count_number = 0
for i in range(1,101): # 从1开始计数到100为止
count_number += i
# 统计综合
print(count_number)
2.判断列表中数2出现的次数
l1 = [11,2,3,2,2,1,2,1,2,3,2,3,2,3,4,3,2,3,2,2,2,2,3,2]
count1 = 0
# 用于统计
l1 = [11, 2, 3, 2, 2, 1, 2, 1, 2, 3, 2, 3, 2, 3, 4, 3, 2, 3, 2, 2, 2, 2, 3, 2]
# 定义l1
for i in l1:
# 遍历l1中的所有数据值
if i == 2:
# 遍历的结果是否为2,如果是2就计数加一
count1 += 1
print(count1)
3.编写代码自动生成所有页网址(注意总共多少页)
https://movie.douban.com/top250
# 我们可以先点进网页观察,发现总共是有10页,然后根据其他页面的网址发现规律:两个网址之前start值差25
# numb = 0
# for i in range(10):
# # 根据观察规律我们只需要改动start的值,规律是每页增加25
# print('https://movie.douban.com/top250?start=%s&filter=' % numb)
# numb += 25
4.编写代码打印出下列图形(ps:for循环嵌套)
'''
这是需要打印的形状
*****
*****
*****
*****
'''
#以下三种方法其实意思差不多的
# 方法一:输出四次,一次输出一行
for i in range(4):
print('*****')
# 方法二:输出两次,一次输出两行
for i in range(2):
print('*****\n*****')
# 方法三:一次性全部输出
for i in range(1):
print('*****\n*****\n*****\n*****')