Python零基础入门-3 流程控制

简介: Python零基础入门-3 流程控制

流程控制即控制代码执行的顺序。Python中的流程控制一般通过判断、循环语句实现。

本文思维导图:

一、判断

1.1 if语句

最常用的判断语句是if语句:

例:if语句

x = int(input("Please enter an integer: "))
if x < 0:
    x = 0
    print('Negative changed to zero')
elif x == 0:
    print('Zero')
elif x == 1:
    print('Single')
else:
    print('More')

注1:这里if下面的语句有4个空格缩进,说明下面的两行语句是属于if语句的。Python中用缩进表示代码所属级别。

注2:elif即对else if的缩写。

(用户输入一个整数存到变量x中,然后对x进行判断。

如果x小于0,就让给x赋值0,并且使用print输出消息Negative changed to zero;否则,如果x等于0,就输出消息Zero;否则,如果x等于1,输出消息Single;否则,以上都不符合,输出消息More。)

if语法:

if 条件:
    命令1
elif 条件:
    命令2
...可以有更多elif...
else:
    命令n

二、循环

2.1 for语句

Python中最常用的循环是for语句。典型用法是用for来遍历一个列表(或任意可迭代对象)

例:使用for语句打印words中单词及其长度。

words = ['cat', 'window', 'defenestrate']
for w in words:
    print(w, len(w))


for -in语法:

for x in 可迭代对象:
    语句

2.2 遍历集合

遍历集合时修改集合的内容,会很容易生成错误的结果。因此不能直接进行循环,而是应遍历该集合的副本或创建新的集合:

#创建一个集合。集合就是一些“键:值”形式的键值对。
users = {'Hans': 'active', 'Éléonore': 'inactive', '景太郎': 'active'}
# 在副本上迭代
for user, status in users.copy().items():
    if status == 'inactive':
        del users[user]
# 或者创建新集合
active_users = {}
for user, status in users.items():
    if status == 'active':
        active_users[user] = status

2.3 range()函数


range可当成是一种不可变序列。 range(start, stop[, step]),range可以传入三个参数,起始值,终止值,步长。其中,start默认值为0,步长默认为1。


range的典型用法就是只指定stop,用于循环指定次数。

for i in range(5):
    print(i)

range(5)就能循环5次:

0
1
2
3
4

range()三参数形式start, stop[, step]:

list(range(0, 10, 3)) #[0, 3, 6, 9]

使用len()和range()可以按索引迭代序列(不推荐)。

a = ['Mary', 'had', 'a', 'little', 'lamb']
for i in range(len(a)):
    print(i, a[i])

推荐使用更简洁的enumerate

a = ['Mary', 'had', 'a', 'little', 'lamb']
for i,x in enumerate(a):
    print(i,x)

2.4 while循环

while循环用于在某些条件下进行循环,条件为假时,循环结束:

a, b = 0, 1
while a < 10:
    print(a)
    a, b = b, a+b

while语法:

while 条件为真:
    执行...

2.5 循环中的break,continue语句

break 语句和 C 中的类似,用于跳出最近的 forwhile 循环。

continue 语句也借鉴自 C 语言,表示继续执行循环的下一次迭代。

for i in range(1, 100):
    if i % 7 == 0 and i % 5 == 0:
        print(i)
        print(i, " is good")

使用break,会直接跳出所在的for循环

#例子break。
for i in range(1,100):
    if i % 7 == 0 and i % 5 == 0:
        print(i)
        break     #会结束所在的for循环
        print(i, " is good")

使用continute会跳过下面的语句,继续下一次循环。

# continue例子
for i in range(1, 100):
    if i % 7 == 0 and i % 5 == 0:
        print(i)
        continue
        print(i, " is good") #会被跳过

2.6 for-else语法(不推荐)

循环结束时执行else,break停止循环时不执行。

# for- else
for i in range(5):
    if i**1 +i**2 + i**3 > 200:
        print("find ",i)
        break
else:
    print("not find")
#not find

循环结束,没有break,就执行else子句。

# for- else
for i in range(10):
    if i**1 +i**2 + i**3 > 200:
        print("find ",i)
        break
else:
    print("not find")
#find  6

循环被break提前结束,不执行else子句。


三、其它

3.1 pass语句

pass语句什么都不做,通常当做占位符。

比如我们预期将来要写一个函数,可以先使用pass占位,后面再实现实际功能。

def initlog(*args):
    pass   # Remember to implement this!

3.2 match

match语句是Python3.10新特性,用来匹配目标。

def http_error(status):
    match status:
        case 400:
            return "Bad request"
        case 404:
            return "Not found"
        case 418:
            return "I'm a teapot"
        case _:
            return "Something's wrong with the internet"

变量名” _ 被作为 通配符 并必定会匹配成功

除了字面值,match还可以匹配模式。

# point is an (x, y) tuple
match point:
    case (0, 0):
        print("Origin")
    case (0, y):
        print(f"Y={y}")
    case (x, 0):
        print(f"X={x}")
    case (x, y):
        print(f"X={x}, Y={y}")
    case _:
        raise ValueError("Not a point")

类形式:

class Point:
    x: int
    y: int
def where_is(point):
    match point:
        case Point(x=0, y=0):
            print("Origin")
        case Point(x=0, y=y):
            print(f"Y={y}")
        case Point(x=x, y=0):
            print(f"X={x}")
        case Point():
            print("Somewhere else")
        case _:
            print("Not a point")


相关文章
|
3天前
|
数据采集 机器学习/深度学习 数据可视化
利用Python和Pandas库构建高效的数据分析流程
在数据驱动的时代,数据分析已成为企业决策的关键环节。本文介绍如何利用Python编程语言及其强大的数据分析库Pandas,构建一套高效且可扩展的数据分析流程。与常规的数据分析流程不同,本文不仅涵盖数据加载、清洗、转换等基础步骤,还强调数据可视化、模型探索与评估等高级分析技巧,并通过实际案例展示如何在Python中实现这些步骤,为数据分析师提供一套完整的数据分析解决方案。
|
3天前
|
数据采集 机器学习/深度学习 数据挖掘
利用Python实现高效的数据清洗与预处理流程
本文旨在探讨如何使用Python编程语言及其强大的数据处理库(如pandas、numpy等)来构建一个高效且灵活的数据清洗与预处理流程。与常规的数据清洗方法不同,本文不仅关注于传统的缺失值填充、异常值处理、数据类型转换等步骤,还引入了数据质量评估、数据特征选择以及自动化处理流程的设计等高级主题。通过实际案例和代码演示,本文将为读者提供一套完整的数据清洗与预处理解决方案,助力数据分析师和数据科学家在数据探索阶段更加高效、准确地处理数据。
|
6天前
|
网络安全 网络虚拟化 数据安全/隐私保护
使用Python实现VPN搭建的流程步骤
保护个人隐私和数据安全变得尤为重要。VPN(虚拟私人网络)是一种有效的解决方案,可以帮助我们在网络上匿名浏览,保护数据传输的安全性。虽然市面上有许多商业VPN服务,但你也可以通过Python自己搭建一个简单的VPN。本文将介绍如何用Python建立自己的VPN。
|
10天前
|
存储 Linux Docker
python项目 以docker形式打包部署全流程
在很久很久以前,我已经听过Docker的大名,当时服务着急上线虽然考虑过用Docker来部署我的服务,但是因为赶期的原因放弃了。 这两天因为华为云服务器到期,而且阿里云服务器优惠力度特别大的原因,我要把华为云服务器里的工程迁移到阿里云。 迁移的过程中,大量的时间精力浪费在了重装python,加载依赖,迁移项目,配置端口等环境配置的工作上。 我在想,如果当时用了Docker部署,我至于受这气?
|
1月前
|
数据采集 机器学习/深度学习 算法
利用Python实现高效的数据清洗与预处理流程
在数据驱动的时代,数据清洗和预处理是数据分析与机器学习项目中至关重要的步骤。本文将介绍如何利用Python的pandas和numpy库,结合正则表达式、数据标准化和缺失值填充等技术,构建一个高效且灵活的数据清洗与预处理流程。文章不仅关注技术细节,还将探讨如何通过流程自动化和模块化来提升数据清洗的效率和准确性。
|
1月前
|
数据采集 数据挖掘 Serverless
利用Python和Pandas库优化数据清洗流程
在数据分析项目中,数据清洗是至关重要的一步。传统的数据清洗方法往往繁琐且易出错。本文将介绍如何利用Python编程语言中的Pandas库,通过其强大的数据处理能力,实现高效、自动化的数据清洗流程。我们将探讨Pandas库在数据清洗中的应用,包括缺失值处理、重复值识别、数据类型转换等,并通过一个实际案例展示如何利用Pandas优化数据清洗流程,提升数据质量。
|
1月前
|
人工智能 数据挖掘 Python
Python基础语法与流程控制
Python基础语法与流程控制
30 1
|
1月前
|
Python
Python中的控制流程详解
Python中的控制流程详解
|
1月前
|
机器学习/深度学习 数据采集 自然语言处理
2024年Python最新【python开发】并发编程(下),2024年最新字节跳动的面试流程
2024年Python最新【python开发】并发编程(下),2024年最新字节跳动的面试流程
2024年Python最新【python开发】并发编程(下),2024年最新字节跳动的面试流程
|
1月前
|
Python
2024年最新【Python】变量 的定义和使用,阿里巴巴蚂蚁金服面试流程
2024年最新【Python】变量 的定义和使用,阿里巴巴蚂蚁金服面试流程
2024年最新【Python】变量 的定义和使用,阿里巴巴蚂蚁金服面试流程