Python - PEP572: 海象运算符

海象运算符

  • PEP572 的标题是「Assignment Expressions」,也就是「赋值表达式」,也叫做「命名表达式」
  • 不过它现在被广泛的别名是「海象运算符」(The Walrus Operator),因为:=很像海象

赋值中间变量

未使用海象运算符

python 复制代码
pattern = re.compile('s')
data = 'ss'
match = pattern.match(data)
if match:
    print(match.group(0))

使用海象运算符优化代码

python 复制代码
pattern = re.compile('s')
data = 'ss'
if match := pattern.match(data):
    print(match.group(0))

使用海象运算符之后,分别做了四件事

  1. 对表达式pattern.match(data)求值
  2. 把第一步的求值结果赋值给 match 变量
  3. 把 match 变量作为 if 的 条件,判断它的值是不是 None
  4. 而 match 变量可以在 if 的作用域范围内继续使用 print(match.group(0)

文件读取的例子

未使用海象运算符

python 复制代码
while 1:
    line = fp.readline()
    if not line:
        break
    print(line)

使用海象运算符优化代码

python 复制代码
while (line := fp.readline()):
    print(line)

仍然做了四件事:

  1. 对表达式fp.readline()求值
  2. 求值结果赋值给 line
  3. 对 line 进行 while 循环的条件判断,如果 None 就退出循环
  4. line 变量可以在 while 循环体内使用

这个就真的简化了很多的代码

简化列表解析

常见使用添加数据到列表的写法

python 复制代码
results = []
for x in data:
    result = f(x)
    if result:
        results.append(result)

假设想使用列表生成式来解决呢?

python 复制代码
results = [
    f(x) for x in data
    if f(x)
]

这样是错误的,为什么?因为会执行两次f(x),不符合实际需求

可以使用海象表达式来优化

python 复制代码
results = [
    y for x in data 
    if (y := f(x))
]

官方例子

python 复制代码
stuff = [[y := f(x), x/y] for x in range(5)]

因为每一项包含了 y,以及要用 y 才能获得结果 x/y,所以 赋值给中间变量是海象运算符的关键

一段迷惑的使用海象操作符的代码

相关推荐
与光同尘 大道至简9 分钟前
ESP32 小智 AI 机器人入门教程从原理到实现(自己云端部署)
人工智能·python·单片机·机器人·github·人机交互·visual studio
清水白石00812 分钟前
深入 Python 对象模型:PyObject 与 PyVarObject 全解析
开发语言·python
tjjucheng17 分钟前
小程序定制开发服务商推荐
python
囊中之锥.18 分钟前
《从零到实战:基于 PyTorch 的手写数字识别完整流程解析》
人工智能·pytorch·python
子云之风25 分钟前
LSPosed 项目编译问题解决方案
java·开发语言·python·学习·android studio
小北方城市网26 分钟前
SpringBoot 全局异常处理与接口规范实战:打造健壮可维护接口
java·spring boot·redis·后端·python·spring·缓存
SunnyRivers1 小时前
打包 Python 项目
python·打包
万行1 小时前
机器人系统SLAM讲解
开发语言·python·决策树·机器学习·机器人
我的xiaodoujiao1 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 40--完善优化 Allure 测试报告显示内容
python·学习·测试工具·pytest
WinstonJQ1 小时前
AirSim无人机仿真入门(一):实现无人机的起飞与降落
python·机器人·游戏引擎·ue4·无人机