首页 > 其他分享 >9月28日——while循环知识不充、for循环、break及continue生效范围和range方法的介绍

9月28日——while循环知识不充、for循环、break及continue生效范围和range方法的介绍

时间:2022-09-28 16:12:40浏览次数:74  
标签:不充 continue while break range 循环 print 死循环

目录

今日内容总结

一、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*****')


标签:不充,continue,while,break,range,循环,print,死循环
From: https://www.cnblogs.com/zhihuanzzh/p/16738449.html

相关文章