Python3.8 特性介绍

发布时间:2019-10-16 17:30:20编辑:auto阅读(2927)

    简介

    Python3.8 已经发布了, 官方文档看这里
    What’s New In Python 3.8.

    介绍一些 Python3.8 中的新特性.

    海象表达式 :=

    新的语法 := 将给变量赋值, 这个变量是更大的表达式的一部分.

    if (n := len(a)) > 10:
      print(f"List is too long ({n} elements, expected <= 10)")

    用在 if 判断中, 避免调用 len() 两次.

    discount = 0.0
    if (mo := re.search(r'(\d+)% discount', advertisement)):
      discount = float(mo.group(1)) / 100.0

    正则表达式匹配和获取结果的时候.

    # Loop over fixed length blocks
    while (block := f.read(256)) != '':
      process(block)

    用在 while 循环中, 可以同时取值, 并判断是否为空.

    [clean_name.title() for name in names
     if (clean_name := normalize('NFC', name)) in allowed_names]

    用在列表推导中.

    完整介绍看 PEP 572.

    仅位置参数 /

    新的函数参数语法 / 指明有些函数参数必须被指定为位置参数, 不能被用作关键字参数.

    def f(a, b, /, c, d, *, e, f):
      print(a, b, c, d, e, f)

    在上面的例子中, a 和 b 是仅位置参数, c 和 d 既可以是位置参数又可以是关键字参数,
    e 和 f 必须是关键字参数.

    >>> def f(a, b, /, **kwargs):
    ...     print(a, b, kwargs)
    ...
    >>> f(10, 20, a=1, b=2, c=3)         # a and b are used in two ways
    10 20 {'a': 1, 'b': 2, 'c': 3}

    仅位置参数的参数名在 **kwargs 中仍旧可用.

    class Counter(dict):
      def __init__(self, iterable=None, /, **kwds):
        # Note "iterable" is a possible keyword argument

    完整介绍看 PEP 570.

    f-strings 说明符 =

    f-strings 增加了 = 说明符, f'{expr=}' 会被扩展为表达式的文本,
    加上一个等号, 和一个执行表达式的结果.

    >>> user = 'eric_idle'
    >>> member_since = date(1975, 7, 31)
    >>> f'{user=} {member_since=}'
    "user='eric_idle' member_since=datetime.date(1975, 7, 31)"

    启动异步 REPL

    使用 python -m asyncio 启动一个异步的 REPL,
    可以直接在 top-level 级别使用 await,
    不用在封装到函数中了.

    unittest 支持异步

    import unittest
    
    class TestRequest(unittest.IsolatedAsyncioTestCase):
    
        async def asyncSetUp(self):
            self.connection = await AsyncConnection()
    
        async def test_get(self):
            response = await self.connection.get("https://example.com")
            self.assertEqual(response.status_code, 200)
    
        async def asyncTearDown(self):
            await self.connection.close()
    
    
    if __name__ == "__main__":
        unittest.main()

关键字