Python类型标注新视角

Python类型标注的全新解读

目录

一. 为何需要类型注解
二. 变量的类型标注
(1) 语法格式
(2) 基础类型
(3) 类对象
(4) 数据容器
(5) 其他语法格式
三. 函数(方法)的类型标注
(1) 形参标注
(2) 返回值标注
四. Union类型

一. 为何需要类型注解

在代码中明确标注数据类型(进行显式说明),使用时可获取相关提示。它能协助像PyCharm这类第三方IDE工具进行类型推断,辅助代码提示。比如,当明确声明某个对象是list类型时,使用该对象时IDE能给出对应提示;而若未声明具体类型,使用时则不会有任何相关提示。

二. 变量的类型标注

用于提示变量的数据类型

(1) 语法格式

变量名: 数据类型 = 具体数值。需注意,Python的类型标注仅起提示作用,解释器不会依据类型标注对数值进行验证与判断,即便不匹配也不会引发错误。

(2) 基础类型

  • 整数类型标注示例:
var_1: int = 1314 
  • 浮点数类型标注示例:
var_2: float = 5.21 
  • 布尔类型标注示例:
var_3: bool = True  
  • 字符串类型标注示例:
var_4: str = "hhybd"  

(3) 类对象

# 定义学生类
class Student:
    pass

stu: Student = Student()  # 学生类类型标注

(4) 数据容器

  • 列表类型标注
  • 方式一:
my_list: list = [1, 2, 3]
  • 方式二(指定列表元素基础类型):
my_list: list[int] = [1, 2, 3]
  • 元组类型标注
  • 方式一:
my_tuple: tuple = (1, 2, 3)
  • 方式二(明确元组每个元素类型):
my_tuple: tuple[str, int, bool] = ("bd", 521, True)
  • 集合类型标注
  • 方式一:
my_set: set = {1, 2, 3}
  • 方式二(指定集合元素基础类型):
my_set: set[int] = {1, 2, 3}
  • 字典类型标注
  • 方式一:
my_dict: dict = {"hhbdy": 250}
  • 方式二(指定字典键值类型):
my_dict: dict[str, int] = {"hhbdy": 250}
  • 字符串类型标注
my_str: str = "hhybd"

(5) 其他语法格式

可在注释中进行类型标注,格式为# type:类型。示例:

stu = Student()  # type:Student
var_1 = 123  # type:int
my_list = [1, 2, 3]  # type:list
my_set = {1, 2, 3}  # type:set[int]

三. 函数(方法)的类型标注

用于标注形参和返回值的数据类型,类型标注仅起提示作用

(1) 形参标注

定义函数(方法)时,给形参加上类型标注。若未标注形参类型,使用形参时工具无提示,调用函数传参时也无法获取参数类型提示。语法格式:

def 函数方法名(形参名1:类型,形参名2:类型):
    函数体

(2) 返回值标注

语法格式:

def 函数方法名(形参名1:类型,形参名2:类型) -> 返回值类型:
    函数体

示例:

def add(x: int, y: int) -> int:
    return x + y

四. Union类型

联合类型标注,可在变量标注、函数(方法)形参和返回值标注中使用。需导入typing模块中的Union,当数据类型不唯一时可使用Union类型。
示例:
变量中使用:

from typing import Union
# 数据为字符串和整数
my_list: list[Union[str, int]] = [2, "hhy", 5, "bd", 0]
# 键为字符串,值为字符串和整数
my_dict: dict[str, Union[str, int]] = {"name": "hhy", "QS": 250}

函数中使用:

from typing import Union

# 接收字符串或整数,返回字符串或整数
def func(data: Union[int, str]) -> Union[int, str]:
    pass

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/13638.html

(0)
LomuLomu
上一篇 2025 年 9 月 19 日
下一篇 2025 年 9 月 19 日

相关推荐

  • 2025年最新PyCharm激活码永久破解教程 – 支持JetBrains全家桶

    本方法适用于JetBrains系列所有产品,包括PyCharm、IDEA、DataGrip、Goland等,一键破解全家桶! 先给大家看看最新版PyCharm成功破解的效果图,可以看到已经完美激活到2099年,绝对稳定可靠! 下面我将用详细的图文教程,手把手教你如何永久激活PyCharm至2099年。 这个方法不仅适用于最新版本,也兼容所有历史版本! Win…

    PyCharm激活码 2025 年 7 月 23 日
    24800
  • CLion破解教程适合开发初学者吗?

    声明:以下教程中涉及的 CLion 破解补丁与激活码均搜集自互联网,仅供个人学习与研究之用,严禁商业用途。若条件允许,请支持正版! 先放一张成果图:CLion 2025.2.1 已顺利激活至 2099 年,稳得一批! 下面用图文方式手把手演示最新版 CLion 的激活流程。 前期准备 如果你曾尝试过其他补丁但未成功,强烈建议先卸载旧版本或清理残留配置,避免冲…

    2025 年 9 月 14 日
    10200
  • 实用型最新idea激活码和详细破解教程合集

    本教程适用于 IDEA、PyCharm、DataGrip、GoLand 等 JetBrains 全家桶,Windows / macOS / Linux 通用! 废话少说,先上图:IDEA 2024.3.5 已成功激活至 2099 年,爽翻! 下面用图文一步步带你搞定,旧版本同样适用,系统不限,我都给你打包好了。 1. 下载安装包(已装可跳过) 打开官网:ht…

    2025 年 10 月 15 日
    22200
  • PyCharm激活教程2024 – 快速破解与安装指南

    本教程适用于PyCharm 2024、IDEA、DataGrip、Goland等Jetbrains产品,支持全家桶激活!无论您使用的是Windows、Mac还是Linux,均可按照本教程成功激活PyCharm 2024至2098年。 激活截图展示 首先,我们来展示一下最新版本的PyCharm 2024破解成功的截图,如下所示,您可以看到已经成功激活至2098…

    2025 年 4 月 23 日
    1.1K00
  • 实用图解版最新版webstorm激活码,分步破解教程教学

    申明:本教程 WebStorm破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 WebStorm 2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的WebStorm。 如果觉得…

    2025 年 12 月 19 日
    2900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信