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 日

相关推荐

  • IDEA永久激活破解教程,亲测有效

    IDEA永久激活破解教程,亲测有效 本文适用于 IDEA、PyCharm、DataGrip、Goland 等 JetBrains 产品,涵盖了 JetBrains 全家桶的激活方法! 激活成功的效果截图 为了让大家更直观地了解激活效果,首先分享一下成功激活 IDEA 到 2099 年的截图,大家可以看到这款软件已经完全激活,使用时无需再担心任何限制! 激活方…

    2025 年 4 月 21 日
    1.8K00
  • 免费下载最新idea激活码资源和独家idea破解教程

    本教程通杀 JetBrains 全家桶:IDEA、PyCharm、DataGrip、Goland 等统统适用! 话不多说,先上图——最新版 IDEA 已顺利“续命”到 2099 年,爽翻! 接下来,我会用图文一步步带你把 IDEA 激活到 2099 年。老版本同样有效,无论你用哪个系统、哪个版本,我都给你准备好了。 下载 IDEA 安装包 如果你已经装好,直…

    IDEA破解教程 2025 年 10 月 16 日
    24600
  • Python窗口编程技艺深度剖析

    文章标题: Python图形用户界面编程技术全方位解读 文章内容: 文章目录 1. Tkinter 简介 示例代码 优势 劣势 2. PyQt/PySide 简介 示例代码(PyQt5) 优势 劣势 3. wxPython 简介 示例代码 优势 劣势 4. Kivy 简介 示例代码 优势 劣势 5. PySimpleGUI 简介 示例代码 优势 劣势 技术对…

    2025 年 7 月 8 日
    44900
  • 2025年最新IDEA激活码分享及永久破解教程(支持2099年)

    JetBrains全家桶通用破解指南 本教程适用于IntelliJ IDEA、PyCharm、DataGrip、Goland等JetBrains系列开发工具,提供一站式破解方案。下面展示的是最新IDEA版本成功破解至2099年的效果图: 接下来将详细介绍如何实现IDEA永久激活,该方法同样适用于历史版本,无论您使用何种操作系统或软件版本,本教程都能完美适配。…

    IDEA破解教程 2025 年 8 月 30 日
    37800
  • 最全goland激活码白嫖渠道与小白专用goland破解教程

    免责声明:以下教程中涉及的 GoLand 破解补丁与激活码均源自网络公开资源,仅供个人学习研究,禁止商用。若条件允许,请支持正版! GoLand 是 JetBrains 出品的一款跨平台 Go 语言 IDE,支持 Windows、macOS 及 Linux。下文将手把手教你利用破解补丁完成永久激活,解锁全部高级特性。 无论你的系统版本或 GoLand 版本如…

    2025 年 10 月 15 日
    44700

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信