更细致的错误语法提示
在调试代码的时候可以精确定位到错误语法的那行,而不是提示 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'?
结构化模式匹配:match...case
相当于其他语言的 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 的严格模式
函数 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
字典增加了 mapping 属性
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 终于来了。