python的强大功能_Python 3.8刚刚发布!一分钟了解新版本的强大功能!-程序员宅基地

技术标签: python的强大功能  

今天Python3.8发布啦,新版本添加了很多全新功能,也表明Python的版本之路前进了一大步,小编整理了新版本的几个主要更新,为大家做详细解读!

顺便一提,导致Python之父龟叔愤然离职的赋值表达式功能还是上线了~

新增赋值表达式

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

在这里给大家展示个通过用PEP 572改写的一行实现斐波那契数列的例子:

In :  (lambda f: f(f, int(input('Input: ')), 1, 0, 1))(lambda f, t, i, a, b: print(f'fib({i}) = {b}') ort== 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说白了就是强制使用者用位置参数

温馨提示:Python3.8版本下,见到以下报错:

TypeError: divmod() takes no keyword arguments

就是这个原因啦!

运行时添加审计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: 

目前支持审计的事件名字和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',)

跨进程内存共享

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

# 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')

全新第三方包读取模块

使用新的 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" andpython_version== "2.7") andextra== \'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')

新增缓存属性

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

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

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

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

REPL对于学习一门新的编程语言非常有帮助,你可以再这个交互环境里面通过输出快速验证你的理解是不是正确。

官方全新增加了一个Asyncio REPL功能,使用更加方便!

F-strings DEBUG

一个新增的调试功能,当然一贯的,对调试毫无帮助。。。。。。

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]

可迭代解包

这个主要是问题修复。

好啦,现在你知道 Python 3.8 的最新功能了吗?

【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39788969/article/details/111451723

智能推荐

sed命令详解_sed '/^$/d-程序员宅基地

文章浏览阅读1.7w次,点赞20次,收藏310次。主要参考:(1)使用sed输出文件的指定行(2)sed 字符串替换(3)sed之添加空行仅供自己学习使用,如有侵权,请联系删除获取指定的行(1) 获取test.txt的第二行,输入到屏幕sed -n 2p test.txt(1) 获取test.txt的第一行至第二行sed -n 1,2p test.txt# 加不加引号均可 sed -n ‘1,2p’ test.txt(2)获取test.txt的第二行至最后一行sed -n '2,$p' test.txt# 必须加单引号(3_sed '/^$/d

音乐推荐数据集Million Song Dataset-程序员宅基地

文章浏览阅读1.4w次,点赞5次,收藏35次。音乐推荐数据集_million song dataset

开箱即用的微服务框架 Go-zero(进阶篇)_gozero 验证参数-程序员宅基地

文章浏览阅读7.1k次,点赞7次,收藏28次。之前我们简单介绍过 Go-zero 详见《Go-zero:开箱即用的微服务框架》。这次我们从动手实现一个 Blog 项目的用户模块出发,详细讲述 Go-zero 的使用。特别说明本文涉及的所有资料都已上传 Github 仓库 “kougazhang/go-zero-demo”, 感兴趣的同学可以自行下载。Go-zero 实战项目:blog本文以 blog 的网站后台为例,着重介绍一下如何使用 Go-zero 开发 blog 的用户模块。用户模块是后台管理系统常见的模块,它的功能大家也非常熟悉。管理用_gozero 验证参数

文件的打开_ctx文档怎么打开 site:blog.csdn.net-程序员宅基地

文章浏览阅读337次。系统调用open打开文件,函数声明如下:#include#include#includeint open(coust char *pathname,int flags);int open(const char *pathname,int flags,made_t mode);pathname 文件名称mode 文件权限调用成功时,返回值为所打开文件的文件描述符,反_ctx文档怎么打开 site:blog.csdn.net

关于SetCapture() 和 ReleaseCapture()的用法_c# releasecapture-程序员宅基地

文章浏览阅读3.2k次。http://blog.csdn.net/lanyzh0909/article/details/5543399查MSND,对SetCapture()函数的说明为:“该函数在属于当前线程的指定窗口里设置鼠标捕获。一旦窗口捕获了鼠标,所有鼠标输入都针对该窗口,无论光标是否在窗口的边界内。同一时刻只能有一个窗口捕获鼠标。如果鼠标光标在另一个线程创建的窗口上,只有当鼠标键按下时系统才将鼠标输入指向_c# releasecapture

NLTK学习(一)_maternal affection on the side of the former-程序员宅基地

文章浏览阅读442次。Python简单入门 交互式开发环境(IDLE)Windows下在开始菜单应用程序那里可以找到,而Unix在shell下输入idle即可运行。我选择的是Sublime Text的代码编辑器,下载安装插件SublimeREPL,下载完之后,在【Tool】【SublimeREPL】【Python】【Python】启动交互式开发环境>>> 1+5*2-38>>> 1/30>>> 1.0/30._maternal affection on the side of the former

随便推点

#Java教程:InputStream、FileinputStream #Java字符输入流 @FDDLC_fileinputstream和inputstream-程序员宅基地

文章浏览阅读1.3k次。一、InputStream..._fileinputstream和inputstream

[转载]在RHEL系统上使用“subscription-manager”注册和激活“subscription”_[root@localhost spdk]# sudo subscription-manager r-程序员宅基地

文章浏览阅读1.3w次。https://nanxiao.me/use-subscription-manager-register-on-rhel/在RHEL系统中注册和使用subscription是两个过程:NOTE: With Red Hat Subscription-Manager, registration and utilization of a subscription is actually a t..._[root@localhost spdk]# sudo subscription-manager register registering to: su

go 与java netty 之间的通信实现_golang可以连netty-程序员宅基地

文章浏览阅读2k次。前言: 笔记上一篇介绍了,go语言如何使用protobuf及生成go的protobuf文件,具体内容请见上一篇:go 与 protobuf 安装和使用1.protobuf文件定义及注意事项// [开始声明]syntax = "proto3"; //定义protobuf的包名称空间package message;// [结束声明]// [开始 java 选项配置]option java_package = "xxxx.core.message";opt..._golang可以连netty

neutron中的安全组和防火墙_安全组的防护对象是?-程序员宅基地

文章浏览阅读3k次。文章来自作者维护的社区微信公众号【虚拟化云计算】)(目前有两个微信群《kvm虚拟化》和《openstack》,扫描二维码点击“云-交流”,进群交流提问)一。防火墙与安全组区别防火墙一般放在网关上,用来隔离子网之间的访问。因此,防火墙即服务也是在网络节点上(具体说来是在路由器命名空间中)来实现。防火墙可以在安全组之前隔离外部过来的恶意流量,但是对于同个子网内部不同虚拟网卡间的通..._安全组的防护对象是?

CodeForces 589B Layer Cake(枚举)_b. layer cake codeforce-程序员宅基地

文章浏览阅读431次。B. Layer Caketime limit per test6 secondsmemory limit per test512 megabytesinputstandard inputoutputstandard outputDasha decided to bake a big and tasty layer c_b. layer cake codeforce

算法笔记 PAT B1023组个最小数_pat b 1023-程序员宅基地

文章浏览阅读161次。就不放原题,直接给自己的思路和代码啦**思路:我其实能想到最简便的方法就是,创建一个char型的数组,然后对数组进行排序,从小到大,然后输出第一个不为0的数,然后再依次输出好吧,由于自己没读题的缘故,发现问题在于输入这部分,那就创建一个数组,数组的位置就是对应的值,数组里的内容就是对应值的数量 **#include<stdio.h>#include<string.h>..._pat b 1023

推荐文章

热门文章

相关标签