扫码阅读
手机扫码阅读

Python 中如何编写类型提示

203 2024-07-19

我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。

查看原文:Python 中如何编写类型提示
文章来源:
咸鱼运维杂谈
扫码关注公众号
文章摘要

Python 类型提示概述

Python 是一种动态类型语言,但为了提高代码的可读性和可维护性,PEP 484 引入了类型提示。类型提示允许开发者为变量、函数的参数和返回值指定类型,使代码更易于理解和调试。详细介绍请参考:类型提示介绍

为函数编写类型提示

类型提示可用于指定函数返回不同类型的数据。例如,使用管道符(|)或Union来表示函数返回值为strNone。Python 3.10 之前使用typing模块的Union,3.10 及以后版本使用管道符。

def parse_email(email_address: str) -> str | None:
    ...

当函数返回多个对象时,默认以元组形式返回,类型提示如下:

def parse_email(email_address: str) -> tuple[str, str] | None:
    ...

使用typing模块的UnionTuple也可以达到相同效果。

为回调函数编写类型提示

在 Python 中,回调函数是可以作为参数传递的函数,类型提示使用Callable。例如:

def apply_func(func: Callable[..., T], *args: Any, **kwargs: Any) -> T:
    ...

其中Callable[..., T]表示回调函数可以接受任意数量的参数,返回类型为T

为生成器编写类型提示

生成器是特殊的迭代器,允许按需生成值。使用yield语句创建,并通过Generator类型进行类型提示。例如:

def parse_email() -> Generator[tuple[str, str], str, str]:
    ...

类型提示Generator[tuple[str, str], str, str]表示生成器会产生一个包含两个字符串的元组,接受str类型的输入,并返回str类型的结果。

生成器也可以使用Iterator进行类型提示,但这样无法指定send类型和return类型。使用Iterable类型提示可以让函数接受任何可迭代对象。

想要了解更多内容?

查看原文:Python 中如何编写类型提示
文章来源:
咸鱼运维杂谈
扫码关注公众号