- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解Python 3.10 中的新功能和变化由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
随着最后一个alpha版发布,Python 3.10 的功能更改全面敲定! 。
现在,正是体验Python 3.10 新功能的理想时间!正如标题所言,本文将给大家分享Python 3.10中所有重要的功能和更改.
在过去, |符号用于 "算术或"运算,例如
1
2
3
|
print
(
0
|
0
)
print
(
0
|
1
)
print
({
1
,
2
} | {
2
,
3
})
|
输出
0 1 {1, 2, 3} 。
在Python 3.10中, |符号有的新语法,可以表示x类型 或 Y类型,以取代之前的typing.Union 完成类型注解 。
举个栗子:
函数的参数应该是一个int 或 str类型 。
旧的写法
1
2
3
4
5
|
from
typing
import
Union
def
f(value: Union[
int
,
str
])
-
> Union[
int
,
str
]:
return
value
*
2
|
新的写法:
1
2
|
def
f(value:
int
|
str
)
-
>
int
|
str
:
return
value
*
2
|
这种新的语法也被作为isinstance() 和issubclass() 的第二个参数,用于类型判断 。
1
|
isinstance
(
1086
,
int
|
str
)
# 10086是否为 int型 或 str型
|
在过去,上下文管理器一般用于资源的自动获取和自动释放,利用打开文件时使用上下文管理器:
1
2
|
with
open
(
"test.txt"
,
"w"
) as f:
# 自动打开和关闭文件
f.write(
"hello, 我是三木"
)
# 对文件进行读写
|
如果要复制文件的话,需要打开源文件和目标文件,那么就需要2个上下文管理器,代码会写成这个样子:
1
2
3
4
|
with
open
(
"test.txt"
,
"r"
) as f:
# 打开第一个文件
with
open
(
"test_copy.txt"
,
"w"
) as f_copy:
# 打开第二个文件
content
=
f.read()
# 从第一个文件获取内容
f_copy.write(content)
# 向第二个文件写入内容
|
在Python3.10中,可以将代码精简一下:
1
2
3
4
5
6
|
with (
open
(
"test.txt"
,
"r"
) as f,
# 打开第一个文件
open
(
"test_copy.txt"
,
"w"
) as f_copy,
# 打开第二个文件
):
content
=
f.read()
# 从第一个文件获取内容
f_copy.write(content)
# 向第二个文件写入内容
|
注意变化:
此外,还可以更加灵(sao)活(qi)的操作:
1
2
3
4
5
6
|
with (
open
(
"test.txt"
,
"r"
, encoding
=
"utf-8"
) as f,
# 打开第一个文件
open
(
"test_copy.txt"
,
"w"
, encoding
=
f.encoding) as f_copy,
# 打开第二个文件
):
content
=
f.read()
# 从第一个文件获取内容
f_copy.write(content)
# 向第二个文件写入内容
|
注意细节:在第2个open中,使用了第一个open的结果 :f 。
如果你熟悉或使用过php,Java或JavaScript等语言,可能见到switch语句,例如这样:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
today
=
new Date().getDay();
switch () {
case
0
:
day
=
"星期天"
;
break
;
case
1
:
day
=
"星期一"
;
break
;
case
2
:
day
=
"星期二"
;
break
;
case
3
:
day
=
"星期三"
;
break
;
case
4
:
day
=
"星期四"
;
break
;
case
5
:
day
=
"星期五"
;
break
;
case
6
:
day
=
"星期六"
;
}
|
简单来说:根据x的值,选择指定的case语句进行执行 。
过去,Python没有这样的语句,所以现在,有了! 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
today
=
1
match today:
case
0
:
day
=
"星期天"
case
1
:
day
=
"星期一"
case
2
:
day
=
"星期二"
case
3
:
day
=
"星期三"
case
4
:
day
=
"星期四"
case
5
:
day
=
"星期五"
case
6
:
day
=
"星期六"
case _:
day
=
"别闹...一个星期只有七天"
print
(day)
|
输出 。
星期一 。
如果将第一行改为today = 8,则输出 。
别闹...一个星期只有七天 。
注意:
关于结构匹配模式(Structural Pattern Matching),可以说是Python 3.10 重量级的新功能,它还有很多高级用法,值得专门一篇文章来进行介绍,这里就先不展开了.
总之,作为一个迟到了的“switch”,会在其他编程语言中的实践经验上进行改进,成符合Python一贯的风格:简单、灵活、强大.
与所有最新的Python版本一样,Python 3.10也带来了一些性能改进。首先是str(),bytes()和bytearray()构造函数的优化,它们的速度应该提高30%~40%左右(来自 https://bugs.python.org/issue41334) 。
1
2
3
4
5
6
|
~ $ .
/
python3.
10
-
m pyperf timeit
-
q
-
-
compare
-
to
=
python
"str()"
Mean
+
-
std dev: [python]
81.9
ns
+
-
4.5
ns
-
> [python3.
10
]
60.0
ns
+
-
1.9
ns:
1.36x
faster (
-
27
%
)
~ $ .
/
python3.
10
-
m pyperf timeit
-
q
-
-
compare
-
to
=
python
"bytes()"
Mean
+
-
std dev: [python]
85.1
ns
+
-
2.2
ns
-
> [python3.
10
]
60.2
ns
+
-
2.3
ns:
1.41x
faster (
-
29
%
)
~ $ .
/
python3.
10
-
m pyperf timeit
-
q
-
-
compare
-
to
=
python
"bytearray()"
Mean
+
-
std dev: [python]
93.5
ns
+
-
2.1
ns
-
> [python3.
10
]
73.1
ns
+
-
1.8
ns:
1.28x
faster (
-
22
%
)
|
此外,还有多个Python核心模块正在进行持续的优化,让我们继续期待吧 。
PEP 618:zip()函数现在具有一个可选strict标志,用于要求所有可迭代对象具有相等的长度 。
首先回顾一下zip函数的用法:
在一个迭代中,同时向多个序列读取内容, 。
可以将行变成列,列变成行,这类似于转置矩阵.
1
2
3
4
5
|
name_list
=
[
'报警'
,
'急救'
,
'消防'
]
number_list
=
[
110
,
120
,
119
]
for
i
in
zip
(name_list, number_list):
print
(i)
|
输出 。
1
2
3
|
(
'报警'
,
110
)
(
'急救'
,
120
)
(
'消防'
,
119
)
|
上面的例子有一个特点:name_list 和 number_list 长度是相同的,如果长度不同会怎么样呢?
1
2
3
4
5
|
name_list
=
[
'报警'
,
'急救'
,
'消防'
,
'查号'
]
number_list
=
[
110
,
120
,
119
]
for
i
in
zip
(name_list, number_list):
print
(i)
|
输出 。
1
2
3
|
(
'报警'
,
110
)
(
'急救'
,
120
)
(
'消防'
,
119
)
|
注意:因为长度不同,所以最后一组结果查号是不会显示的,但是却没有任何提示,从结果来看,无法判断是否有遗漏的数据.
在Python 3.10,可以给zip()传递参数strict=True,对长度进行严格检查 。
1
2
|
for
i
in
zip
(name_list, number_list, strict
=
True
):
print
(i)
|
输出 。
1
2
3
4
5
6
7
|
(
'报警'
,
110
)
(
'急救'
,
120
)
(
'消防'
,
119
)
Traceback (most recent call last):
File
"C:\Users\san\PycharmProjects\py310\a.py"
, line
4
,
in
<module>
for
i
in
zip
(name_list, number_list, strict
=
True
):
ValueError:
zip
() argument
2
is
shorter than argument
1
|
注意: zip的第二个参数比第一个参数短,于是抛出异常 。
以上就是详解Python 3.10 中的新功能和变化的详细内容,更多关于Python 3.10 中的新功能和变化的资料请关注我其它相关文章! 。
原文链接:https://www.cnblogs.com/dongfangtianyu/p/14713895.html 。
最后此篇关于详解Python 3.10 中的新功能和变化的文章就讲到这里了,如果你想了解更多关于详解Python 3.10 中的新功能和变化的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
嘿伙计们。 实现背景变化(基本上是幻灯片放映)和过渡效果的常见方法有哪些。我想每隔一段时间改变complte文档背景。 我是一名 ASP.net 开发人员,并且希望大部分内容都可以在 ASP 中实现。
也许,指针已经在修改过程中指向 auto_ptr 的常规指针指向 unique_ptr 和 shared_ptr 我只是想知道已经开发出来的新型指针是否完全覆盖了旧版本(或者您可能认为存在内存泄漏问题
我使用 Android Studio 构建 Android 应用。 我的问题是:当 fragment 改变时,应用程序崩溃。 控制台输出[控制台] 01-06 18:35:21.952 27756-
****澄清**我做了这个 [Fiddle] ( http://jsfiddle.net/sggPv/10/ ) 来帮助澄清情况。 该脚本起初适用于两个表格,但随后当您点击 slider 并将新表格加
我有图标,单击它会将新的 div(列)添加到 div 容器。问题是,当新的 div(列)出现时,按钮不会向右移动。是否可以以某种方式仅在 div 内添加 position:fixed? 这是我的几个屏
我是 Java 新手,继承了现有的 Android 应用程序。原始开发人员选择使用常量接口(interface)。 我的问题是我需要更改其中一些常量来编译生产应用程序与开发应用程序。如果我手动修改一些
在 Apple developer Document 中,我在 UIColor 中发现了一些新东西。 If your app was linked on or after iOS 10 and whe
我没有经常使用 ShareKit,但我只想拥有三个共享选项:Facebook、Twitter 和电子邮件。 ShareKit 提供了更多选项,包括更多按钮。但是,我不想要“更多”选项,只想要三个。 在
我正在构建一个 JS 库,其中一个用例要求我在 DOM 更改时触发一个事件,特别是如果它是一个单页应用程序,例如:github search bar 经过一番研究,我遇到了MutationObserv
我已经设法编写了一个代码来检测任何工作表中特定单元格的值变化,但我一直在努力构建检测和跟踪范围(值)变化的东西。 例如,如果用户决定复制和粘贴某个范围的数据(假设超过 1 个单元格),它不会被宏捕获。
使用 ffmpeg ,我们可以对音频电平进行多少控制?例如,我想在程序的时间轴上映射一个“M”形: t0 - t1 : fade in from 0 to 1 t1 - t2 : play at fu
使用 jQuery 1.7.1,我尝试为下拉列表上的更改事件创建一个事件处理程序。下拉列表会动态添加到 DOM 中。似乎在大多数浏览器上都能很好地工作,但是哦,奇怪的 IE8 想要变得困难。有解决方法
我想制作一个具有可选边框大小的自定义控件。请参阅下面的代码。边框绘制在非客户区,其宽度可以是 0、1 或 2 像素。我已经在 WM_NCPAINT 中成功完成了边框绘制。问题是,在更改控制边框大小的属
我知道这个问题之前已经被问过,而且我实际上已经找到了一些我已经实现的解决方案。不幸的是,我没能得到我想要的。 我以前没有做过AngularJS,我想做的是: 检测网址何时更改 根据网址更改的内容进行一
我有一个 auto-carousel 指令,它循环访问链接元素的子元素。 但是,子级尚未加载到 DOM 中,因为它们的 ng-if 表达式尚未解析。 如何确保父指令知道其 DOM 树已发生更改?
我有一个流程可以通过内容提供商从数据库中获取数据。 fun getDataFlow(): Flow { return flow { emit(Result.Loading)
我有一些有效的代码,但有时它只是“跳转”到其他文本而不考虑间隔。 该代码基本上按时间间隔更改标题的文本。 var text = ["text1", "text2", "text3","text4","
我正在尝试将 onCLick 监听器添加到我的 PreferenceScreen 上的开关,但它不起作用。我尝试了 Java 教程中的代码并将其转换为 Kotlin,但由于某种原因它无法正常工作。 这
我们目前正在尝试升级我们的程序使用的 ffmpeg 版本。跳跃很大,因为我们目前使用的是 ffmpeg 0.8,最新版本是 1.2。 在这些测试中,我使用的是(让我说)我发现的令人惊叹的软件包 her
我有一个流程可以通过内容提供商从数据库中获取数据。 fun getDataFlow(): Flow { return flow { emit(Result.Loading)
我是一名优秀的程序员,十分优秀!