京公网安备 11010802034615号
经营许可证编号:京B2-20210330
作者:某某白米饭
来源:Python 技术
python 3.10 已经在 10月 4 号发布了,这次更新了错误语法提示对 python 新手更加友好。好几个新的特性非常的有用,一起来看看吧。
在调试代码的时候可以精确定位到错误语法的那行,而不是提示 SyntaxError 的行。
# 1 expected = {9: 1, 18: 2, 19: 2, 27: 3, some_other_code = foo() # 2 foo(x, z for z in range(10), t, w) # 3 try: build_dyson_sphere() except NotEnoughScienceError, NotEnoughResourcesError: # 4 f"Black holes {*all_black_holes} and revelations" # 5 schwarzschild_black_hole = None schwarschild_black_hole
3.9 提示的是
# 1 some_other_code = foo() ^ SyntaxError: invalid syntax # 2 foo(x, z for z in range(10), t, w) ^ SyntaxError: Generator expression must be parenthesized # 3 except NotEnoughScienceError, NotEnoughResourcesError: ^ SyntaxError: invalid syntax # 4 (*all_black_holes) ^ SyntaxError: f-string: can't use starred expression here # 5 schwarschild_black_hole NameError: name 'schwarschild_black_hole' is not defined
3.10 提示的是
# 1 expected = {9: 1, 18: 2, 19: 2, 27: 3, ^ SyntaxError: '{' was never closed # 2 foo(x, z for z in range(10), t, w) ^^^^^^^^^^^^^^^^^^^^ SyntaxError: Generator expression must be parenthesized # 3 except NotEnoughScienceError, NotEnoughResourcesError: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ SyntaxError: multiple exception types must be parenthesized # 4 (*all_black_holes) ^^^^^^^^^^^^^^^^ SyntaxError: f-string: cannot use starred expression here # 5 schwarschild_black_hole NameError: name 'schwarschild_black_hole' is not defined. Did you mean: 'schwarzschild_black_hole'?
相当于其他语言的 switch...case
match subject:
case <pattern_1>: <action_1> case <pattern_2>: <action_2> case <pattern_3>: <action_3> case _: <action_wildcard>
关键字 match 后跟变量名。 如果匹配,则将执行 case 块内的语句, 没有匹配,则执行 case _ 块内的语句。
# 1 for i in [1,2,3,4,5,6,7]:
match i: case 1: print('周一') case 2: print('周二') case 3: print('周三') case 4: print('周四') case 5: print('周五') case _: print('放假了')
结果:
# 1 周一
周二
周三
周四
周五
放假了
放假了
再来一个 tuple 类型的
# 2 point = (1, 2, 3)
match point:
case (0, 0, _):
print("原点")
case (0, y, 0):
print(f"Y={y}")
case (x, 0, 0):
print(f"X={x}")
case (x, y, z):
print(f"X={x}, Y={y}, Z={z}")
case _: raise ValueError("Not a point")
结果:
# 2 X=1, Y=2, Z=3
可以使用 tuple 类型,当然也可以使用 list 类型,类似于:points = [(1, 3),(1, 2)]
以 X|Y 的形式引入了新的类型联合运算符。
def square(number: int|float): return number ** 2 print(square(4))
print(square(4.4))
结果:
16 19.360000000000003
也可以用作 isinstance():一个对象是否是一个已知的类型 和 issubclass():判断参数 class 是否是类型参数 classinfo 的子类 的第二个参数。
isinstance("5",int|str)
isinstance("xxxx",int|str)
结果:
True True
函数 zip() 增加 strict 参数,如果设置 strict = True,而传输的参数的长度不相等将会抛出异常。
x = [1,2,3,4,5] y = [1,2,3] z = zip(x,y, strict=True) print(list(z))
结果:
ValueError: zip() argument 2 is shorter than argument 1
dict.items()、dict.keys()、dict.values() 分别增加了 mapping 属性
x = {'name': '张三', 'age': 14} keys = x.keys() values = x.values()
items = x.items() print(keys.mapping) print(values.mapping) print(items.mapping)
python 3.10 更新的最有用的就是错误提示了,再也不会看到提示一团迷糊,定位更加的精确,match...case 终于来了。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数字化商业环境中,数据已成为企业优化运营、抢占市场、规避风险的核心资产。但商业数据分析绝非“堆砌数据、生成报表”的简单 ...
2026-01-20定量报告的核心价值是传递数据洞察,但密密麻麻的表格、复杂的计算公式、晦涩的数值罗列,往往让读者望而却步,导致核心信息被淹 ...
2026-01-20在CDA(Certified Data Analyst)数据分析师的工作场景中,“精准分类与回归预测”是高频核心需求——比如预测用户是否流失、判 ...
2026-01-20在建筑工程造价工作中,清单汇总分类是核心环节之一,尤其是针对楼梯、楼梯间这类包含多个分项工程(如混凝土浇筑、钢筋制作、扶 ...
2026-01-19数据清洗是数据分析的“前置必修课”,其核心目标是剔除无效信息、修正错误数据,让原始数据具备准确性、一致性与可用性。在实际 ...
2026-01-19在CDA(Certified Data Analyst)数据分析师的日常工作中,常面临“无标签高维数据难以归类、群体规律模糊”的痛点——比如海量 ...
2026-01-19在数据仓库与数据分析体系中,维度表与事实表是构建结构化数据模型的核心组件,二者如同“骨架”与“血肉”,协同支撑起各类业务 ...
2026-01-16在游戏行业“存量竞争”的当下,玩家留存率直接决定游戏的生命周期与商业价值。一款游戏即便拥有出色的画面与玩法,若无法精准识 ...
2026-01-16为配合CDA考试中心的 2025 版 CDA Level III 认证新大纲落地,CDA 网校正式推出新大纲更新后的第一套官方模拟题。该模拟题严格遵 ...
2026-01-16在数据驱动决策的时代,数据分析已成为企业运营、产品优化、业务增长的核心工具。但实际工作中,很多数据分析项目看似流程完整, ...
2026-01-15在CDA(Certified Data Analyst)数据分析师的日常工作中,“高维数据处理”是高频痛点——比如用户画像包含“浏览次数、停留时 ...
2026-01-15在教育测量与评价领域,百分制考试成绩的分布规律是评估教学效果、优化命题设计的核心依据,而正态分布则是其中最具代表性的分布 ...
2026-01-15在用户从“接触产品”到“完成核心目标”的全链路中,流失是必然存在的——电商用户可能“浏览商品却未下单”,APP新用户可能“ ...
2026-01-14在产品增长的核心指标体系中,次日留存率是当之无愧的“入门级关键指标”——它直接反映用户对产品的首次体验反馈,是判断产品是 ...
2026-01-14在CDA(Certified Data Analyst)数据分析师的业务实操中,“分类预测”是高频核心需求——比如“预测用户是否会购买商品”“判 ...
2026-01-14在数字化时代,用户的每一次操作——无论是电商平台的“浏览-加购-下单”、APP的“登录-点击-留存”,还是金融产品的“注册-实名 ...
2026-01-13在数据驱动决策的时代,“数据质量决定分析价值”已成为行业共识。数据库、日志系统、第三方平台等渠道采集的原始数据,往往存在 ...
2026-01-13在CDA(Certified Data Analyst)数据分析师的核心能力体系中,“通过数据建立模型、实现预测与归因”是进阶关键——比如“预测 ...
2026-01-13在企业数字化转型过程中,业务模型与数据模型是两大核心支撑体系:业务模型承载“业务应该如何运转”的逻辑,数据模型解决“数据 ...
2026-01-12当前手游市场进入存量竞争时代,“拉新难、留存更难”成为行业普遍痛点。对于手游产品而言,用户留存率不仅直接决定产品的生命周 ...
2026-01-12