Python 中的类型注解是一种用于描述变量、函数参数和返回值预期类型的机制

简介: 【5月更文挑战第8天】Python的类型注解提升代码可读性和可维护性,虽非强制,但利于静态类型检查(如Mypy)。包括:变量注解、函数参数和返回值注解,使用内置或`typing`模块的复杂类型,自定义类型注解,以及泛型模拟。类型注解可在变量声明、函数定义和注释中使用,帮助避免类型错误,提高开发效率。

Python 中的类型注解是一种用于描述变量、函数参数和返回值预期类型的机制。这种机制虽然不强制要求类型匹配,但有助于代码的可读性、可维护性,以及静态类型检查工具(如 Mypy)的使用。下面列举 Python 中类型注解的一些主要方面:

  1. 变量类型注解
    变量类型注解用于说明变量的预期类型。虽然 Python 是动态类型语言,但类型注解可以帮助开发者和其他阅读代码的人更好地理解变量的用途。

python
name: str = "Alice"
age: int = 30

  1. 函数参数和返回值类型注解
    函数参数和返回值也可以使用类型注解,以明确函数接受什么类型的参数以及返回什么类型的值。

python
def greet(name: str) -> None:
print(f"Hello, {name}!")

def add(a: int, b: int) -> int:
return a + b

  1. 使用内置类型
    Python 的内置类型,如 int、str、float、bool、list、tuple、dict 等,都可以直接用作类型注解。

python
def example_function(num: int, text: str) -> tuple[int, str]:
return num, text

  1. 使用 typing 模块提供的类型
    typing 模块提供了许多额外的类型,用于更复杂的场景,如泛型、可调用对象、类型变量等。

python
from typing import List, Dict, Callable, TypeVar

T = TypeVar('T') # 定义类型变量

def first_item(items: List[T]) -> T:
return items[0]

def register_callback(callback: Callable[[int], None]) -> None:

# ...  

def get_user_info(user_id: int) -> Dict[str, str]:

# ...
  1. 自定义类型的注解
    你也可以使用自定义的类或类型作为类型注解。

python
class Person:
def init(self, name: str, age: int):
self.name = name
self.age = age

def introduce(person: Person) -> None:
print(f"My name is {person.name} and I am {person.age} years old.")

  1. 泛型注解
    虽然 Python 没有像 Java 或 C# 那样的原生泛型支持,但你可以使用 typing 模块中的 TypeVar 和泛型类型(如 List[T]、Dict[K, V])来模拟泛型行为。

python
from typing import TypeVar, List

T = TypeVar('T')

def longest_item(items: List[T]) -> T:
return max(items, key=len)
在这个例子中,longest_item 函数可以接受任何类型的列表,并返回列表中长度最长的元素。由于使用了泛型,这个函数可以处理字符串列表、字节串列表、或者其他任何可以比较长度的对象列表。

  1. 注释中的类型注解
    虽然不推荐,但在某些情况下,你可能需要在注释中而不是使用冒号进行类型注解。这主要是为了与旧版本的 Python 或某些工具兼容。

python

type: ignore

type: (int) -> str

def convert_to_string(num):
return str(num)
请注意,这种方式现在已经被视为过时,并推荐使用冒号进行类型注解。

类型注解是 Python 中一个强大的特性,它使得代码更加清晰、易于理解,并且可以与静态类型检查工具一起使用,以在运行时之前捕获潜在的类型错误。

相关文章
|
1月前
|
Python
[oeasy]python050_如何删除变量_del_delete_variable
本文介绍了Python中如何删除变量,通过`del`关键字实现。首先回顾了变量的声明与赋值,说明变量在声明前是不存在的,通过声明赋予其生命和初始值。使用`locals()`函数可查看当前作用域内的所有本地变量。进一步探讨了变量的生命周期,包括自然死亡(程序结束时自动释放)和手动删除(使用`del`关键字)。最后指出,删除后的变量将无法在当前作用域中被访问,并提供了相关示例代码及图像辅助理解。
115 68
|
2月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
146 67
|
13天前
|
分布式计算 MaxCompute 对象存储
|
8天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
20 3
|
11天前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
24 2
|
27天前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
1月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
52 18
|
30天前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
62 8
|
1月前
|
Shell Python
[oeasy]python049_[词根溯源]locals_现在都定义了哪些变量
本文介绍了Python中`locals()`函数的使用方法及其在调试中的作用。通过回顾变量赋值、连等赋值、解包赋值等内容,文章详细解释了如何利用`locals()`函数查看当前作用域内的本地变量,并探讨了变量声明前后以及导入模块对本地变量的影响。最后,文章还涉及了一些与“local”相关的英语词汇,如`locate`、`allocate`等,帮助读者更好地理解“本地”概念在编程及日常生活中的应用。
36 9
|
1月前
|
Python
Python中的函数
Python中的函数
46 8