文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python 编码中需要写类型注解的原因是什么

2023-06-14 06:16

关注

这篇文章将为大家详细讲解有关python 编码中需要写类型注解的原因是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

使用方式

2.1、 Python3内置的类型注解

内置注解肯能大家都接触过,但总感觉很麻烦,导致后面很容易就放弃写注解,这是因为得到不正反馈,看如下示例:

a: str = "aa"b: int = 1# 参数和返回标注了类型,那么接下来调用时就能进行提示def example(a: str) -> str: return f"Hello {a}"pirnt(example("world"))# # 一些简单的标注,看起来起不到效果,但如果换个有含义的名字呢User = strAge = intAnswer = strdef say_hello(u: User) -> Answer: return f"Hello {u}"print(say_hello("Shadow"))

上面简单演示了内置的类型注解是如何使用的,但是其实这么简单的类型注解并不能帮助我们很好的标注变量;下面介绍一个typing模块

2.2、typing 模块的快速入门

typing 模块是类型注解的主角,Python运行时不强制执行函数和变量类型注解,但这些注解可用于类型检查器、IDE、静态检查器等第三方工具。这些第三方工具会在我们编码时进行提示与纠错;

下面提供一些日常使用到的方法与用例给大家参考:

import typing# 自定义类型注解User = strAge = int# 定义有多种类型注解的类型AnyStr = typing.TypeVar('AnyStr', str, bytes)a_str: AnyStr = "a"a_bytes: AnyStr = b"a"# 通用类型, 接收通用的类型,尽量少的去使用def example_1(a: typing.Any):  print(a)"""typing 模块是允许使用下标来辅助标记类型"""# 列表, 下标为列表的属性def example_2(a_list: typing.List[User]) -> typing.List[str]:  pass# 字典,下标第一个为key,第二个为valuedef example_3(a_dict: typing.Dict[User, Age]) -> typing.Dict[str, int]:  pass# 元祖,下标为元祖的属性def example_4(a_tuple: typing.Tuple[User] = None) -> typing.Tuple[User]:  pass# Union, 在一些场景下我们某些参数或返回值是不确定,至少给定一个参数类型def example_5(a_b: typing.Union[str, int]) -> typing.Union[str, int]:  pass# Optional, 与Union 有点类似,但默认多带一个None,至少给定一个参数类型# 如:Optional[str] 等价于 Union[str, None]def example_6(a: str) -> typing.Optional[str]:  pass# Tuple, 返回值有多个的时候, 如需要返回str, int, bool, floatdef example_7() -> typing.Tuple[str, int, bool, float]:  pass# class, 类本身也是一种类型class Action:  up: str = "up"  down: str = "down"# 指定需求一个action对象的参数def example_8(action_obj: Action) -> Action:  pass# 这样在一些枚举参数的场景下,我们也可以使用类作为我们枚举参数的归类def example_9(action_cls: Action) -> Action:  pass# 如果上面的枚举参数你觉得并不能很好的实现,那么还是可以使用自定义类型注解的方式去实现Action = strup: Action = "up"down: Action = "down"# 在python3.9 中对枚举参数类型有更好的支持MODE = type.Literal['r', 'rb', 'w', 'wb']def open_file(file: str, mode: MODE) -> str:  passopen_file('/some/path', 'r') # 正常open_file('/other/path', 'typo') # 会提示该类型不合法# Type, 在一些多态类的场景下标注同一个类型的不同的形态class User: ...class BasicUser(User): ...class ProUser(User): ...class TeamUser(User): ...# 相当于 typing.Union[User, BasicUser, ProUser, TeamUser]def make_new_user(user_class: typing.Type[User]) -> User:  return user_class()

关于python 编码中需要写类型注解的原因是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯