Python 3.8正式发布,来尝鲜这些新特性吧


Posted in Python onOctober 15, 2019

今天 Python3.8 发布啦,它是 Python2 终结前最后一个大版本,我们一起看看这个版本都添加了那些新功能和特性。

PEP 572: Assignment Expressions

PEP 572 的标题是赋值表达式,也叫做「命名表达式」,不过它现在被广泛的别名是「海象运算符」(The Walrus Operator)。因为:= 很像海象「眼睛小,长着两枚长长的牙」这个特点 ^_^。

具体内容可以看我之前写的文章: PEP572: 海象运算符 ,在这里给大家展示个通过用 PEP 572 改写的一行实现斐波那契数列的例子:

In : (lambda f: f(f, int(input('Input: ')), 1, 0, 1))(lambda f, t, i, a, b: print(f'fib({i}) = {b}') or t == i or f
 ...: (f, t, i + 1, b, a + b))
Input: 10
fib(1) = 1
fib(2) = 1
fib(3) = 2
fib(4) = 3
fib(5) = 5
fib(6) = 8
fib(7) = 13
fib(8) = 21
fib(9) = 34
fib(10) = 55
Out: True

基于 Raymond Hettinger 版本改写:

In : [(t:=(t[1], sum(t)) if i else (0,1))[1] for i in range(10)]
Out: [1, 1, 2, 3, 5, 8, 13, 21, 34, 55]
PEP 570: Python Positional-Only parameters

PEP 570 说白了就是 强制使用者用位置参数

具体的可以看我之前写的文章: PEP570 新语法:只接受位置参数

PEP 578: Python Runtime Audit Hooks

现在可以给 Python 运行时添加审计钩子:

In : import sys
...: import urllib.request
...:
...:
...: def audit_hook(event, args):
...: if event in ['urllib.Request']:
...: print(f'Network {event=} {args=}')
...:
...: sys.addaudithook(audit_hook)

In : urllib.request.urlopen('https://httpbin.org/get?a=1')
Network event='urllib.Request' args=('https://httpbin.org/get?a=1', None, {}, 'GET')
Out: <http.client.HTTPResponse at 0x10e394310>

目前支持审计的事件名字和 API 可以看 PEP 文档 (延伸阅读链接 2), urllib.Request 是其中之一。另外还可以自定义事件:

In : def audit_hook(event, args):
...: if event in ['make_request']:
...: print(f'Network {event=} {args=}')
...:

In : sys.addaudithook(audit_hook)

In : sys.audit('make_request', 'https://baidu.com')
Network event='make_request' args=('https://baidu.com',)

In : sys.audit('make_request', 'https://douban.com')
Network event='make_request' args=('https://douban.com',)
Multiprocessing shared memory

可以跨进程直接访问同一内存 (共享):

# IPython进程A
In : from multiprocessing import shared_memory

In : a = shared_memory.ShareableList([1, 'a', 0.1])

In : a
Out: ShareableList([1, 'a', 0.1], name='psm_d5d6ba1b') # 注意name
# IPython进程B(另外一个终端进入IPython)
In : from multiprocessing import shared_memory

In : b = shared_memory.ShareableList(name='psm_d5d6ba1b') # 使用name就可以共享内存

In : b
Out: ShareableList([1, 'a', 0.1], name='psm_d5d6ba1b')
New importlib.metadata module

使用新的 importlib.metadata 模块可以直接读取第三方包的元数据:

In : from importlib.metadata import version, files, requires, distribution

In : version('flask')
Out: '1.1.1'

In : requires('requests')
Out:
['chardet (<3.1.0,>=3.0.2)',
 'idna (<2.9,>=2.5)',
 'urllib3 (!=1.25.0,!=1.25.1,<1.26,>=1.21.1)',
 'certifi (>=2017.4.17)',
 "pyOpenSSL (>=0.14) ; extra == 'security'",
 "cryptography (>=1.3.4) ; extra == 'security'",
 "idna (>=2.0.0) ; extra == 'security'",
 "PySocks (!=1.5.7,>=1.5.6) ; extra == 'socks'",
 'win-inet-pton ; (sys_platform == "win32" and python_version == "2.7") and extra == \'socks\'']

In : dist = distribution('celery')

In : dist.version
Out: '4.3.0'

In : dist.metadata['Requires-Python']
Out: '>=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*'

In : dist.metadata['License']

In : dist.entry_points
Out:
[EntryPoint(name='celery', value='celery.__main__:main', group='console_scripts'),
 EntryPoint(name='celery', value='celery.contrib.pytest', group='pytest11')]

In : files('celery')[8]
Out: PackagePath('celery/__init__.py')

In : dist.locate_file(files('celery')[8])
Out: PosixPath('/Users/dongweiming/test/venv/lib/python3.8/site-packages/celery/__init__.py')
functools.cached_property

缓存属性 (cached_property) 是一个非常常用的功能,很多知名 Python 项目都自己实现过它,现在终于进入版本库了。

具体的可以看我之前写的文章: functools.cached_property(Python 3.8)

functools.lru_cache 作为装饰器时可以不加参数

lru_cache 装饰器支持 max_size 和 typed 2 个参数,如果对默认参数不敏感,过去只能这么用 (需要空括号):

In : @lru_cache()
...: def add(a, b):
...: return a + b
...:

从 3.8 开始可以直接作为装饰器,而不是作为返回装饰器的函数 (不加括号):

In : @lru_cache
...: def add(a, b):
...: return a + b
...:

就像 dataclasses.dataclass ,绝大部分场景都是这么用:

@dataclass
class InventoryItem:
 ...

其实 dataclass 支持多个参数:

def dataclass(cls=None, /, *, init=True, repr=True, eq=True, order=False,
 unsafe_hash=False, frozen=False):

所以这种使用全部缺省值的装饰器工厂用法中,括号反而显得多余了。

Asyncio REPL

具体的可以看我之前写的文章: asyncio REPL(Python 3.8)

F-strings DEBUG

具体的可以看我之前写的文章: 使用 f-strings 调试 (Python3.8)

Async Mock

单元测试模块 unittest 添加了 mock 异步代码的类:

In : import asyncio

In : from unittest.mock import AsyncMock, MagicMock

In : mock = AsyncMock(return_value={'json': 123})
In : await mock()
Out: {'json': 123}

In : asyncio.run(mock())
Out: {'json': 123}

In : async def main(*args, **kwargs):
...: return await mock(*args, **kwargs)
...:

In : asyncio.run(main())
Out: {'json': 123}

In : mock = MagicMock() # AsyncMock也可以

In : mock.__aiter__.return_value = [1, 2, 3]

In : async def main():
...: return [i async for i in mock]
...:

In : asyncio.run(main())
Out: [1, 2, 3]
Generalized iterable unpacking in yield and return

具体的可以看我之前写的文章: Python3.8 对「可迭代解包」的改进

后记

全部更改详情请查阅 Changelog (延伸阅读链接 1),另外推荐阅读延伸阅读链接 3 和 4,都是非常好的补充

延伸阅读

https://docs.python.org/3.8/whatsnew/3.8.html

https://www.python.org/dev/peps/pep-0578/#id11

https://speakerdeck.com/matrixise/whats-new-in-python-3-dot-8

https://realpython.com/python38-new-features/

总结

以上所述是小编给大家介绍的Python 3.8正式发布,来尝鲜这些新特性吧,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python2.x中文乱码问题解决方法
Jun 02 Python
Python检测生僻字的实现方法
Oct 23 Python
python paramiko模块学习分享
Aug 23 Python
python SSH模块登录,远程机执行shell命令实例解析
Jan 12 Python
python分治法求二维数组局部峰值方法
Apr 03 Python
PyQt5每天必学之像素图控件QPixmap
Apr 19 Python
详解pyenv下使用python matplotlib模块的问题解决
Nov 29 Python
用xpath获取指定标签下的所有text的实例
Jan 02 Python
Pyorch之numpy与torch之间相互转换方式
Dec 31 Python
python scatter函数用法实例详解
Feb 11 Python
Pyspark获取并处理RDD数据代码实例
Mar 27 Python
Python 开发工具通过 agent 代理使用的方法
Sep 27 Python
Python3安装pip工具的详细步骤
Oct 14 #Python
python区分不同数据类型的方法
Oct 14 #Python
django中瀑布流写法实例代码
Oct 14 #Python
python 中Arduino串口传输数据到电脑并保存至excel表格
Oct 14 #Python
python实现文件批量编码转换及注意事项
Oct 14 #Python
python 正则表达式贪婪模式与非贪婪模式原理、用法实例分析
Oct 14 #Python
Python协程操作之gevent(yield阻塞,greenlet),协程实现多任务(有规律的交替协作执行)用法详解
Oct 14 #Python
You might like
php str_replace的替换漏洞
2008/03/15 PHP
php下HTTP Response中的Chunked编码实现方法
2008/11/19 PHP
FirePHP 推荐一款PHP调试工具
2011/04/23 PHP
PHP7正式版测试,性能惊艳!
2015/12/08 PHP
ThinkPHP框架表单验证操作方法
2017/07/19 PHP
createElement与createDocumentFragment的点点区别小结
2011/12/19 Javascript
JS正则表达式获取分组内容的方法详解
2013/11/15 Javascript
判断客户浏览器是否支持cookie的示例代码
2013/12/23 Javascript
JavaScript用Number方法实现string转int
2014/05/13 Javascript
canvas实现粒子时钟效果
2017/02/06 Javascript
JavaScript中offsetWidth的bug及解决方法
2017/05/17 Javascript
单行 JS 实现移动端金钱格式的输入规则
2017/05/22 Javascript
vue.js移动端app实战1:初始配置详解
2017/07/24 Javascript
ReactJS实现表单的单选多选和反选的示例
2017/10/13 Javascript
原生js实现的金山打字小游戏(实例代码详解)
2020/03/16 Javascript
[02:28]PWL开团时刻DAY3——Ink Ice与DeMonsTer之间的勾心斗角
2020/11/03 DOTA
[02:04]2020年夜魇暗潮预告片
2020/10/30 DOTA
python提示No module named images的解决方法
2014/09/29 Python
Python中的两个内置模块介绍
2015/04/05 Python
浅谈flask截获所有访问及before/after_request修饰器
2018/01/18 Python
使用python语言,比较两个字符串是否相同的实例
2018/06/29 Python
python 文本单词提取和词频统计的实例
2018/12/22 Python
使用Django简单编写一个XSS平台的方法步骤
2019/03/25 Python
python字符串中匹配数字的正则表达式
2019/07/03 Python
python pandas 时间日期的处理实现
2019/07/30 Python
win10下opencv-python特定版本手动安装与pip自动安装教程
2020/03/05 Python
Python实现CAN报文转换工具教程
2020/05/05 Python
Python如何优雅删除字符列表空字符及None元素
2020/06/25 Python
2013年学期结束动员演讲稿
2014/01/07 职场文书
中层干部培训方案
2014/06/16 职场文书
治庸问责心得体会
2014/09/12 职场文书
个人事迹材料范文
2014/12/29 职场文书
少年雷锋观后感
2015/06/10 职场文书
python小程序之飘落的银杏
2021/04/17 Python
Python利用Turtle绘制哆啦A梦和小猪佩奇
2022/04/04 Python
《英雄联盟》2022日蚀、月蚀皮肤演示 黑潮亚索曝光
2022/04/13 其他游戏