Python-流程控制总结(if、elif、else、for、while(2)

计数循环

使用cnt进行计数

cnt = 0
while cnt < 5:
    print(f'第{cnt+1}次循环')
    cnt += 1 

结果:

第1次循环
第2次循环
第3次循环
第4次循环
第5次循环

do…while???

在C++中你可以找到doo…while,然而,python中没有。python的开发者希望语言变得更简单,如果不是有人使用语言中的其他关键字模仿三元操作符经常出错,甚至连if…else实现三元操作符也不会有。当然,do…while的实现就很简单了,使用一个flag即可,do…while就是先做,然后再判断。

举例:

import random
flag = True
while flag:
    num = random.choice(range(10))
    print(num)
    if num < 4:
        flag = False

结果(当然,你的结果和我的可能不一样):

8
3

continue与break

continue用于停止本次循环,进入下次循环;break用于跳出循环。两个关键字让循环变得更灵活。

小综合举例:

cnt = 3
password = 'lady_killer9'
while cnt != 0:
    pwd = input('please input your password:')
    if pwd == password:
        print('log in success')
        break
    else:
        print('password not right!!!')
        cnt -= 1
        continue

结果:

E:\Workspace\python_workspace\learnpy>python learncondition.py
please input your password:hi
password not right!!!
please input your password:lady
password not right!!!
please input your password:lady_killer
password not right!!!

E:\Workspace\python_workspace\learnpy>python learncondition.py
please input your password:hello
password not right!!!
please input your password:lady_killer9
log in success

pass

python使用缩进而不是{},有些时候语法上需要写语句,但是我们又希望什么都不要做,这个时候就可以使用pass。

举例(找到对3取余为1的数):

num = 0
nums = [1, 2, 5, 6, 4, 7]
for i in nums:
    if i % 3 == 1:
        print('找到了:', i)
        continue
    if i % 2 == 0:
        print('偶数但不符合')
    else:
        pass

结果:

找到了: 1
偶数但不符合
偶数但不符合
找到了: 4
找到了: 7

i为5时,pass掉了

循环中的else

循环语句可能带有一个 else 子句;它会在循环遍历完列表 (使用for) 或是在条件变为假 (使用while) 的时候被执行,但是不会在循环被break语句终止时被执行。也就是说,循环没有被break终止,那么就执行else后的语句。

寻找最大因子

普通:

def showMaxFactor(num):
    flag = False
    count = int(num/2)
    while count > 1:
        if num % count == 0:
            print(f'largest factor of {num} if {count}')
            flag = True
            break
        count -= 1
    if not flag:
        print(num, 'is prime')


for n in range(10, 21):
    showMaxFactor(n)

结果:

largest factor of 10 if 5
11 is prime
largest factor of 12 if 6
13 is prime
largest factor of 14 if 7
largest factor of 15 if 5
largest factor of 16 if 8
17 is prime
largest factor of 18 if 9
19 is prime
largest factor of 20 if 10

else写法:

def showMaxFactor(num):
    count = int(num/2)
    while count > 1:
        if num % count == 0:
            print(f'largest factor of {num} if {count}')
            break
        count -= 1
    else:
        print(num, 'is prime')

内置函数

enumerate(iterable, start=0)

返回一个枚举对象。iterable 必须是一个序列,或迭代器,或其他支持迭代的对象。enumerate()返回的迭代器的__next__()方法返回一个元组,里面包含一个计数值(从 start 开始,默认为 0)和通过迭代 iterable 获得的值。

当在序列中循环时,可以将索引位置和其对应的值同时取出

lst = [7, 0, 'a', 'b', 7, '345', 67, 'lady', 'killer', 78, '9', 'lady_killer9', 4, 6]
for i, v in enumerate(lst):
    if v == 'lady_killer9':
        lst.pop(i)
print(lst)

结果:

[7, 0, ‘a’, ‘b’, 7, ‘345’, 67, ‘lady’, ‘killer’, 78, ‘9’, 4, 6]

range(start, stop[, step])

一个不可变的序列类型,start可以大于stop,step可以为负数

for i in range(len(lst) - 1, -1, -1):
    print(lst[i], sep=' ', end=' ')

结果:

6 4 lady_killer9 9 78 killer lady 67 345 7 b a 0 7

zip(*iterables)

创建一个聚合了来自每个可迭代对象中的元素的迭代器。

返回一个元组的迭代器,其中的第 i 个元组包含来自每个参数序列或可迭代对象的第 i 个元素。 当所输入可迭代对象中最短的一个被耗尽时,迭代器将停止迭代。 当只有一个可迭代对象参数时,它将返回一个单元组的迭代器。 不带参数时,它将返回一个空迭代器。

x = [1, 2, 3]
y = [4, 5, 6]
zipped = zip(x, y)
print(list(zipped))
print(list(zip(*zip(x, y))))
for k, v in zip(x, y):
    if v == 2 * k:
        print(k, v)

结果:

[(1, 4), (2, 5), (3, 6)]
[(1, 2, 3), (4, 5, 6)]
3 6

更多python相关内容:【python总结】python学习框架梳理

一、网安学习成长路线图

网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、网安视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
在这里插入图片描述

三、精品网安学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
在这里插入图片描述

四、网络安全源码合集+工具包

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
在这里插入图片描述

五、网络安全面试题

最后就是大家最关心的网络安全面试题板块
在这里插入图片描述在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 26
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值