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

结果:

[3, 3, 4, 1]

while

循环语句,与if相比,若满足条件,一直运行,而不是一次。

while expression:
    something need to repeat
无限循环

while True即可,不再举例

计数循环

使用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)

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

还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!

王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。

对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!

【完整版领取方式在文末!!】

93道网络安全面试题

内容实在太多,不一一截图了

黑客学习资源推荐

最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

😝朋友们如果有需要的话,可以联系领取~

1️⃣零基础入门
① 学习路线

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

image

② 路线对应学习视频

同时每个成长路线对应的板块都有配套的视频提供:

image-20231025112050764

2️⃣视频配套工具&国内外网安书籍、文档
① 工具

② 视频

image1

③ 书籍

image2

资源较为敏感,未展示全面,需要的最下面获取

在这里插入图片描述在这里插入图片描述

② 简历模板

在这里插入图片描述

因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆

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

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值