Python 3.10的几个好用的新特性

简介: Python 3.10的几个好用的新特性

3.10版没有添加新的模块,但是引入了很多新的并且有用的特性。让我们来一起看看吧。

更详细语法错误提示信息

在调试代码时,能够提供更多的错误新信息和提示了,报告可以指出错误的语法,而不仅仅是提供“Syntax Error”。

这是个新的特性简直是太好了,不仅对于刚开始学习python的人来说对于所有人都是一个好消息,再也不需要去一个字一个字的看了。python 3.10会提示我们错误的位置,再也不需要StackOverflow了,哈。

640.png

结构模式匹配

结构模式匹配以 match 语句和 case 语句的形式使用。模式可以是序列、映射、python原始数据类型和类实例。我们可以把它看作switch 语句的加强版, 一个简单的例子:-

numbers= [1,2,3,4]
forninnumbers:
matchn:
case1:
print("Number is 1")
case2:
print("Number is 2")
case3:
print("Number is 3")
case_:
print("Number is not 1,2 or 3")

关键字match后跟变量名称。如果匹配,则将执行 case 块内的语句。如果没有匹配,则执行 case _ 块内的语句。

上面的程序结果如下所示:

Numberis1Numberis2Numberis3Numberisnot1,2or3

这种结构模式匹配还适用于复杂模式。

defhuman_age(person): #person= (name, age, gender)
matchperson:
case (name, _, "male"):
print(f"{name} is man.")
case (name, _, "female"):
print(f"{name} is woman.")
case (name, age, gender):
print(f"{name} is {age} old.")

结果是这样的:

human_age(("Carol", 25, "female"))
Caroliswoman.

很像Scala啊,使用3.10的Pyspark应该会简单很多,这里贴个Scala代码,看看是不是很像

importscala.util.Randomvalx: Int=Random.nextInt(10)
xmatch {
case0=>"zero"case1=>"one"case2=>"two"case_=>"other"}


新型联合运算符

以 X|Y 的形式引入了新的类型联合运算符。这提供了表达 X 型或 Y 型的清晰形式。

defsquare(number: int|float):
returnnumber**2

结果:

square(2.5)
6.25

新的运算符也可以用作 isinstance() 和 issubclass() 的第二个参数。

isinstance("3",int|str)
Trueisinstance("GoodBye",int|str)
True

现有模块的一些改进

pprint() 添加了一个新的关键字参数-underscore_numbers。

>>>pprint.pformat(int(1e9),underscore_numbers=True)
'1_000_000_000'

我们可以使用int.bit_count() 来计算整数的二进制表示中的位数。

value=50print(bin(value))
0b101010print(value.bit_count())
3

有点像numpy的bincount啊

Statistics增加了协方差函数

>>>importstatistics>>>x= [1, 2, 3, 4, 5, 6, 7, 8, 9]
>>>y= [1, 2, 3, 1, 2, 3, 1, 2, 3]
>>>statistics.covariance(x,y)
0.75

statistics.correlation()还能计算Pearson相关系数。

这俩我没想明白为什么要加,可能我作为AI开发,np,scipy和pandas都是必装,web开发也用不到这些吧,实在没懂加这个是为什么。

statistics.linear_regression()这个就好玩了,虽然也没什么用但是statistics可以计算线性回归了。

根据此线性函数描述自变量 x 和因变量 y 之间的关系:-

y = 斜率 * x + 截距 + 噪声

其中斜率和截距是估计的回归参数,噪声表示数据的可变性。

>>>years= [2001,2005,2010]
>>>houses_built= [5,8,14]
>>>slope, intercept=statistics.linear_regression(years, houses_built)
>>>round(slope*2017+intercept)
21

下一步加个梯度的反向传播,statistics模块就可以训练MLP了,哈

总结

其他的像Cpython之类的我觉得关系不大的就不细说了,3.10的语法提示真是太香了,绝对可以节省不少的开发调试时间,模式匹配也是个好东西,用过Scala的都知道。

最后就是我们到底要不要升级呢?对于我来说,我的python版本是根据Pytorch走的,Pytorch支持哪版我就用那版。虽然有Conda可以管理版本,但是还有很多其他的Python包还不知道支持不支持3.10,所以我的建议是再等等看吧,毕竟我们是拿来用的自己用的舒服才好。但是要是不考虑其他包兼容的问题3.10我肯定优先升级。

目录
相关文章
|
29天前
|
Python
闭包(Closure)是**Python中的一种高级特性
闭包(Closure)是**Python中的一种高级特性
41 8
|
3月前
|
存储 大数据 数据处理
Python 中的列表推导式与生成器:特性、用途与区别
Python 中的列表推导式与生成器:特性、用途与区别
36 2
|
4月前
|
机器学习/深度学习 人工智能 安全
python和Java的区别以及特性
Python:适合快速开发、易于维护、学习成本低、灵活高效。如果你需要快速上手,写脚本、数据处理、做点机器学习,Python就是你的首选。 Java:适合大型项目、企业级应用,性能要求较高的场景。它类型安全、跨平台能力强,而且有丰富的生态,适合更复杂和规模化的开发。
79 3
|
3月前
|
设计模式 监控 安全
Python多线程编程:特性、挑战与最佳实践
Python多线程编程:特性、挑战与最佳实践
46 0
|
3月前
|
设计模式 监控 安全
Python多线程编程:特性、挑战与最佳实践【1】
Python多线程编程:特性、挑战与最佳实践【1】
38 0
|
5月前
|
存储 数据库 C++
"深入剖析Python元组(tuple):与列表的对比、特性解析及高效应用场景展示"
【8月更文挑战第9天】Python元组与列表虽均用于存储元素集合,但有本质差异。元组不可变,创建后无法修改,适合保护数据不被意外更改的场景,如作字典键或传递固定值。列表则可变,支持动态增删改,适用于需频繁调整的数据集。元组因不可变性而在性能上有优势,可用于快速查找。两者各有千秋,根据具体需求选择使用。例如,元组可用于表示坐标点或日期,而列表更适合管理用户列表或库存。
140 1
|
5月前
|
安全 算法 Go
Python面向对象的三大特性
python面向对象编程(OOP)的三大特性是封装、继承和多态。这些特性共同构成了OOP的基础,使得软件设计更加灵活、可维护和可扩展。
52 3
|
5月前
|
机器学习/深度学习 运维 数据挖掘
scikit-learn 1.0 版本重要新特性一览
scikit-learn 1.0 版本重要新特性一览
|
6月前
|
机器学习/深度学习 数据采集 前端开发
网络爬虫开发:JavaScript与Python特性的小差异
我们以前写JavaScript的代码时,在遇到了发送请求时,都是需要去await的。 但是为什么Python代码不需要这样做呢? 这就是因为JavaScript是异步的,Python是同步的。 JavaScript就需要使用关键词await将异步代码块变为同步代码。
|
6月前
|
数据库 开发者 Python
Python 3.9的新特性有哪些?
【7月更文挑战第2天】Python 3.9的新特性有哪些?
69 1