
作者:某某白米饭
来源: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
解析 loss.backward ():深度学习中梯度汇总与同步的自动触发核心 在深度学习模型训练流程中,loss.backward()是连接 “前向计算 ...
2025-09-02要解答 “画 K-S 图时横轴是等距还是等频” 的问题,需先明确 K-S 图的核心用途(检验样本分布与理论分布的一致性),再结合横轴 ...
2025-09-02CDA 数据分析师:助力企业破解数据需求与数据分析需求难题 在数字化浪潮席卷全球的当下,数据已成为企业核心战略资产。无论是市 ...
2025-09-02Power BI 度量值实战:基于每月收入与税金占比计算累计税金分摊金额 在企业财务分析中,税金分摊是成本核算与利润统计的核心环节 ...
2025-09-01巧用 ALTER TABLE rent ADD INDEX:租房系统数据库性能优化实践 在租房管理系统中,rent表是核心业务表之一,通常存储租赁订单信 ...
2025-09-01CDA 数据分析师:企业数字化转型的核心引擎 —— 从能力落地到价值跃迁 当数字化转型从 “选择题” 变为企业生存的 “必答题”, ...
2025-09-01数据清洗工具全景指南:从入门到进阶的实操路径 在数据驱动决策的链条中,“数据清洗” 是决定后续分析与建模有效性的 “第一道 ...
2025-08-29机器学习中的参数优化:以预测结果为核心的闭环调优路径 在机器学习模型落地中,“参数” 是连接 “数据” 与 “预测结果” 的关 ...
2025-08-29CDA 数据分析与量化策略分析流程:协同落地数据驱动价值 在数据驱动决策的实践中,“流程” 是确保价值落地的核心骨架 ——CDA ...
2025-08-29CDA含金量分析 在数字经济与人工智能深度融合的时代,数据驱动决策已成为企业核心竞争力的关键要素。CDA(Certified Data Analys ...
2025-08-28CDA认证:数据时代的职业通行证 当海通证券的交易大厅里闪烁的屏幕实时跳动着市场数据,当苏州银行的数字金融部连夜部署新的风控 ...
2025-08-28PCU:游戏运营的 “实时晴雨表”—— 从数据监控到运营决策的落地指南 在游戏行业,DAU(日活跃用户)、MAU(月活跃用户)是衡量 ...
2025-08-28Excel 聚类分析:零代码实现数据分群,赋能中小团队业务决策 在数字化转型中,“数据分群” 是企业理解用户、优化运营的核心手段 ...
2025-08-28CDA 数据分析师:数字化时代数据思维的践行者与价值推动者 当数字经济成为全球经济增长的核心引擎,数据已从 “辅助性信息” 跃 ...
2025-08-28ALTER TABLE ADD 多个 INDEX:数据库批量索引优化的高效实践 在数据库运维与性能优化中,索引是提升查询效率的核心手段。当业务 ...
2025-08-27Power BI 去重函数:数据清洗与精准分析的核心工具 在企业数据分析流程中,数据质量直接决定分析结果的可靠性。Power BI 作为主 ...
2025-08-27CDA 数据分析师:数据探索与统计分析的实践与价值 在数字化浪潮席卷各行业的当下,数据已成为企业核心资产,而 CDA(Certif ...
2025-08-27t 检验与 Wilcoxon 检验:数据差异比较的两大统计利器 在数据分析中,“比较差异” 是核心需求之一 —— 如新药疗效是否优于旧药 ...
2025-08-26季节性分解外推法:解锁时间序列预测的规律密码 在商业决策、资源调度、政策制定等领域,准确的预测是规避风险、提升效率的关键 ...
2025-08-26CDA 数据分析师:数据治理驱动下的企业数据价值守护者 在数字经济时代,数据已成为企业核心战略资产,其价值的释放离不开高 ...
2025-08-26