当前位置: 首页 > article >正文

程序代码篇---Python指明函数参数类型


文章目录

  • 前言
  • 简介
  • 一、函数参数的类型指定
    • 1. 基本类型提示
    • 2. 默认参数
    • 3. 可变参数
    • 4. 联合类型(Union)
    • 5. 可选类型(Optional)
    • 6. 复杂类型
  • 二、返回值的类型指定
    • 1. 基本返回类型
    • 2. 无返回值(None)
    • 3. 返回多个值(Tuple)
    • 4. 生成器(Generator)
  • 三、高级类型提示用法
    • 1. 类型别名(Type Aliases)
    • 2. 泛型(Generics)
    • 3. 可调用对象(Callable)
    • 4. NewType
  • 四、工具支持与检查
    • 1. 静态类型检查(mypy)
    • 2. IDE支持
  • 五、综合示例
  • 六、注意事项
    • 运行时无强制检测
    • 兼容性
    • 动态类型优势
    • 通过合理使用类型提示
  • 七、总结


前言

本文仅仅简单介绍了Python中函数参数的提前指明的使用。


简介

在Python中,类型提示(Type Hints)用于明确函数参数和返回值的预期类型,提升代码可读性和维护性,并支持静态类型检查工具(如mypy)。以下是详细说明及示例代码:

一、函数参数的类型指定

1. 基本类型提示

直接在参数后添加类型注解:

def greet(name: str, age: int) -> None:print(f"Hello, {name}. You are {age} years old.")

2. 默认参数

在默认值前添加类型注解:

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

3. 可变参数

*args:使用Tuple或Iterable:

def sum_numbers(*args: float) -> float:return sum(args)

**kwargs:使用Dict指定键值类型:

def print_kwargs(**kwargs: str) -> None:for key, value in kwargs.items():print(f"{key}: {value}")

4. 联合类型(Union)

允许多种可能的类型(Python 3.10+ 可使用 | 语法):

from typing import Uniondef parse_input(value: Union[int, str]) -> int:return int(value)
#Python 3.10+ 简化写法
def parse_input(value: int | str) -> int:return int(value)

5. 可选类型(Optional)

表示参数可以是某类型或None:

from typing import Optionaldef find_user(name: str) -> Optional[str]:if name == "admin":return "Admin User"return None

6. 复杂类型

列表、字典:

from typing import List, Dictdef process_items(items: List[str], prices: Dict[str, float]) -> None:for item in items:print(f"Item: {item}, Price: {prices.get(item, 0.0)}")

自定义类:

class User:def __init__(self, name: str):self.name = namedef create_user(name: str) -> User:return User(name)

二、返回值的类型指定

1. 基本返回类型

直接指定返回值类型:

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

2. 无返回值(None)

明确函数没有返回值:

def log_message(message: str) -> None:print(f"[LOG] {message}")

3. 返回多个值(Tuple)

使用Tuple指定多个返回值的类型:

from typing import Tupledef split_name(full_name: str) -> Tuple[str, str]:first, last = full_name.split()return first, last

4. 生成器(Generator)

指定生成器的产出值、发送值和返回值类型:

from typing import Generatordef count_up_to(n: int) -> Generator[int, None, None]:count = 1while count <= n:yield countcount += 1

三、高级类型提示用法

1. 类型别名(Type Aliases)

简化复杂类型声明:

from typing import List, TupleCoordinates = List[Tuple[float, float]]def plot_points(points: Coordinates) -> None:for x, y in points:print(f"Plotting at ({x}, {y})")

2. 泛型(Generics)

使用TypeVar定义泛型类型:

from typing import TypeVar, ListT = TypeVar('T')def first_element(items: List[T]) -> T:return items[0]

3. 可调用对象(Callable)

标注回调函数的类型:

from typing import Callabledef on_event(callback: Callable[[str, int], None]) -> None:callback("click", 100)

4. NewType

创建更明确的类型:

from typing import NewTypeUserId = NewType("UserId", int)def get_user(user_id: UserId) -> str:return f"User {user_id}"

四、工具支持与检查

1. 静态类型检查(mypy)

安装与使用:

pip install mypy
mypy your_script.py

2. IDE支持

PyCharm/VSCode:自动补全和类型错误提示。
Jupyter Notebook:部分支持类型提示。

五、综合示例

from typing import Union, List, Optional, Tuple#参数类型:联合类型 + 默认参数
def format_data(data: Union[List[int], str],prefix: str = "Data: "
) -> Optional[str]:if isinstance(data, list):return prefix + ", ".join(map(str, data))elif isinstance(data, str):return prefix + datareturn None#返回值类型:Tuple
def analyze_numbers(numbers: List[float]) -> Tuple[float, float]:avg = sum(numbers) / len(numbers)max_val = max(numbers)return avg, max_val#泛型函数
from typing import TypeVarT = TypeVar("T")def filter_list(items: List[T], condition: Callable[[T], bool]) -> List[T]:return [item for item in items if condition(item)]#使用示例
if __name__ == "__main__":print(format_data([1, 2, 3]))  # 输出: Data: 1, 2, 3avg, max_val = analyze_numbers([10.5, 20.3, 15.2])print(f"Average: {avg}, Max: {max_val}")  # 输出: Average: 15.333..., Max: 20.3

六、注意事项

运行时无强制检测

运行时无强制检查:类型提示不会影响代码执行,需依赖工具(如mypy)检查。

兼容性

兼容性:Python 3.5+ 支持基础类型提示,部分高级特性需更高版本。

动态类型优势

动态类型优势:类型提示不破坏Python的灵活性,可选择性使用。

通过合理使用类型提示

通过合理使用类型提示,可以显著提升代码的可维护性和团队协作效率。


七、总结

以上就是今天要讲的内容,本文仅仅简单介绍了Python中函数参数的提前指明的使用。

相关文章:

程序代码篇---Python指明函数参数类型

文章目录 前言简介一、函数参数的类型指定1. 基本类型提示2. 默认参数3. 可变参数4. 联合类型&#xff08;Union&#xff09;5. 可选类型&#xff08;Optional&#xff09;6. 复杂类型 二、返回值的类型指定1. 基本返回类型2. 无返回值&#xff08;None&#xff09;3. 返回多个…...

【论文阅读】SAM-CP:将SAM与组合提示结合起来的多功能分割

导言 近年来&#xff0c;视觉基础模型的快速发展推动了多模态理解的进步&#xff0c;尤其是在图像分割任务中。例如&#xff0c;Segment Anything模型&#xff08;SAM&#xff09;在图像Mask分割上表现出色&#xff0c;但在语义及实例分割方面仍存在局限。本文提出的SAM-CP&am…...

ecovadis社会企业责任认证

EcoVadis 是一家全球性的企业社会责任 (CSR) 评级机构&#xff0c;旨在通过评估企业在环境、劳工与人权、商业道德和可持续采购等方面的表现&#xff0c;帮助提升其可持续性和社会责任实践。 EcoVadis 认证的核心内容 环境 评估企业在能源消耗、碳排放、废物管理等方面的表现。…...

机器视觉3D中,深度图与点云图数据对比分析

在机器视觉3D中,深度图(Depth Map)和点云图(Point Cloud)是两种不同的数据表示形式,主要区别如下: 数据维度与结构 深度图 二维矩阵:每个像素存储对应场景中某一点的深度值(即到相机的距离)。 坐标系:基于图像坐标系(2D),每个像素的坐标是 (u, v),对应的深度值为…...

逻辑架构与软件架构在PREEvision中的设计关系

1 Introduction 在如今汽车电子系统的开发过程中&#xff0c;系统架构设计是至关重要的环节。无论是汽车控制系统、信息娱乐系统&#xff0c;还是电动驱动系统&#xff0c;架构设计都决定了整个系统的功能、性能以及后期的可维护性和可扩展性。 在往期文章中&#xff0c;我们…...

机器学习和深度神经网络 参数调参数 太麻烦,非常费时间怎么办,用自动化超参数优化方法

自动化超参数优化方法主要包括以下几种‌&#xff1a; ‌网格搜索&#xff08;Grid Search&#xff09;‌&#xff1a;网格搜索是通过在给定的超参数搜索空间内尝试所有可能的组合&#xff0c;最后找出最优的超参数组合。这种方法虽然直观&#xff0c;但计算成本较高&#xff0…...

武汉火影数字|VR沉浸式空间制作 VR大空间打造

VR沉浸式空间制作是指通过虚拟现实技术创建一个逼真的三维环境&#xff0c;让用户能够沉浸在这个环境中&#xff0c;彷佛置身于一个全新的世界。 也许你会好奇&#xff0c;VR 沉浸式空间究竟是如何将我们带入那奇妙的虚拟世界的呢&#xff1f;这背后&#xff0c;离不开一系列关…...

MQTT的连接配置以及重连机制和遇到的问题--------求如何修改更加好

今天遇到了一个mqtt的问题&#xff0c;虽然解决了&#xff0c;但是感觉不是很好&#xff0c;希望大家多指点 这是配置文件 customer:mqtt:broker: tcp://ip:1883clientList:- clientId: nays_servicesubscribeTopic: xxxxxx- clientId: receive_servicesubscribeTopic: xxxxx…...

大数据学习之任务流调度系统Azkaban、Superset可视化系统

一.任务流调度系统Azkaban 1.课程介绍 2.为什么需要工作流调度系统 3.AZKABAN是什么 4.AZKABAN下载 5.制作安装包 6.tar包准备 7.MYSQL配置AZKABAN 8.配置EXECUTOR SERVER 9.配置WEBSERVER 10.单作业实战_yaml语言(今天稍晚更新) 11.单作业实战 12.多作业依赖实战 13.失败自动重…...

在VS-qt的程序中,后期增加PCH预编译功能,提高编译速度

由于前期创建qt程序的时候未勾选pch功能,导致没有启动预编译的功能. 这种情况下需要增加pch功能应该怎么做? 在项目中增加2个文件 stdafx.h和stdafx.cpp文件 stdafx.h增加qt常用头文件 #pragma once //windows #include <windows.h>//qt常用 #include <QObject&g…...

蓝桥云客 路径之谜

11.路径之谜 - 蓝桥云课 路径之谜 题目描述 小明冒充X星球的骑士&#xff0c;进入了一个奇怪的城堡。 城堡里边什么都没有&#xff0c;只有方形石头铺成的地面。 假设城堡地面是nn个方格。如下图所示。 按习俗&#xff0c;骑士要从西北角走到东南角。可以横向或纵向移动&…...

ES6相关操作

一.JavaScript的基础语法 1.Demo1.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>JavaScrip…...

在Linux上创建一个Docker容器并在其中执行Python脚本

在Linux上创建一个Docker容器并在其中执行Python脚本的过程&#xff0c;涉及多个方面的内容&#xff0c;包括安装Docker、编写Dockerfile、构建镜像、运行容器等。 1. 安装Docker 在Linux上使用Docker之前&#xff0c;你需要确保系统已安装Docker。Docker支持的Linux发行版有…...

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_os_init 函数

ngx_os_init 声明在 src/os/unix/ngx_os.h ngx_int_t ngx_os_init(ngx_log_t *log); 定义在 src\os\unix\ngx_posix_init.c ngx_int_t ngx_os_init(ngx_log_t *log) {ngx_time_t *tp;ngx_uint_t n; #if (NGX_HAVE_LEVEL1_DCACHE_LINESIZE)long size; #endif#if (NGX…...

【Python项目】基于Python的语音数据及标注核对审核系统

【Python项目】基于Python的语音数据及标注核对审核系统 技术简介&#xff1a; 采用Python技术、MySQL数据库、Django框架等实现。 系统简介&#xff1a; 语音数据及标注核对审核系统是一个基于B/S架构的语音数据处理平台&#xff0c;旨在通过自动化的方式对语音数据进行标…...

深入解析BFS算法:C++实现无权图最短路径的高效解决方案

在无权图中&#xff0c;广度优先搜索&#xff08;BFS&#xff09;是解决最短路径问题的高效算法。接下来博主从专业角度深入探讨其实现细节&#xff0c;并给出C代码示例&#xff1a; 目录 一、核心原理 二、算法步骤 三、C实现关键点 1. 数据结构 2. 边界检查 3. 路径回溯…...

LeetCode刷题---二分查找---441

排列硬币 441. 排列硬币 - 力扣&#xff08;LeetCode&#xff09; 题目 你总共有 n 枚硬币&#xff0c;并计划将它们按阶梯状排列。对于一个由 k 行组成的阶梯&#xff0c;其第 i 行必须正好有 i 枚硬币。阶梯的最后一行 可能 是不完整的。 给你一个数字 n &#xff0c;计算…...

Unity结合Vuforia虚拟按键实现AR机械仿真动画效果

零、最终效果 待上传 一、资源准备 1、Vuforia Vuforia版本不能高于10.17.4&#xff08;往上的版本虚拟按键功能被删除&#xff09; 2、Unity Unity版本必须要高于2022.3.x&#xff0c;不然使用Vuforia插件时会出现bug 二、主要内容 1、添加虚拟按钮 2、为虚拟按钮设置…...

网络安全 linux学习计划 linux网络安全精要

&#x1f345; 点击文末小卡片 &#xff0c;免费获取网络安全全套资料&#xff0c;资料在手&#xff0c;涨薪更快 2.使用命令行 文件系统层次标准&#xff08;FHS&#xff09;是一个文件和目录在Unix和Linux操作系统上面应该如何存储的定义。 /bin 重要的二进制可执行程序/bo…...

深度解析2025最新微服务版本特性

当程序猿张三在凌晨三点对着满屏报错日志抓狂时&#xff0c;他绝对想不到2025年的微服务架构已经进化成了会哄睡的技术保姆。这年头要是谁家系统还像俄罗斯套娃般环环相扣&#xff0c;出门都不好意思跟同行打招呼。且看这群代码世界的乐高大师们&#xff0c;今年又给我们整了哪…...

世界棒球经典赛(World Baseball Classic)·棒球1号位

世界棒球经典赛&#xff08;World Baseball Classic&#xff09;是一项由美国职棒大联盟&#xff08;MLB&#xff09;和国际棒球总会&#xff08;IBAF&#xff0c;现更名为世界棒垒球联盟WBSC&#xff09;共同主办的国际棒球赛事。该赛事吸引了来自世界各地的顶尖棒球队伍参与&…...

为AI聊天工具添加一个知识系统 之115 详细设计之56 知识表征 之2

本文要点 要点 知识表征的顶级范畴中最好是先将九个原语primitive T, ⊥, Independent, Relative, Mediating, Physical, Abstract, Continuant,和 Occurrent 进行分组&#xff08;分成2大组 和 4个小组&#xff09;并写出它们的满足公司&#xff0c;然后将它们和三种设计&am…...

rust 实例化动态对象

在功能开发中&#xff0c;动态创建或获取某个对象的情况很多。在前端JS开发中&#xff0c;可以使用工厂函数&#xff0c;通过给定的类型标识创建不同的对象实例&#xff1b;还可以通过对象映射来实现动态创建对象。 在Rust中&#xff0c;我们也可以使用这两种方式去创建对象实…...

支持向量机 (Support Vector Machine, SVM)

支持向量机 (Support Vector Machine, SVM) 支持向量机&#xff08;SVM&#xff09;是一种广泛应用于分类、回归分析以及异常检测的监督学习算法。它基于结构风险最小化&#xff08;Structural Risk Minimization&#xff0c;SRM&#xff09;原则&#xff0c;通过寻找一个最优…...

C#初级教程(1)——C# 与.NET 框架:探索微软平台编程的强大组合

图片来源&#xff1a; https://www.lvhang.site/docs/dotnettimeline 即梦AI - 一站式AI创作平台 一、历史发展脉络 在早期的微软平台编程中&#xff0c;常用的编程语言有 Visual Basic、C、C。到了 20 世纪 90 年代末&#xff0c;Win32 API、MFC&#xff08;Microsoft Found…...

Mac m1 连接公司内网

1、创建VPN 1、在系统偏好设置 2、选择网络 3、进行添加 2、添加设置 1、选择VPN 2、类型选择L2TP/IPSec 3、填写服务器IP和账号 4、点击认证设置-填写密码 。然后应用 3、进行特殊配置 网上说苹果系统的问题。 1、创建命令 sudo vim /etc/ppp/options 2、添加内容-主要别…...

C++:类与对象,定义类和构造函数

#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> using namespace std; //如何让定义一个类 // 封装 // 1、将数据和方法定义到一起。 // 2、把想给你看的数据给你看&#xff0c;不想给你看的封装起来。 通过访问限定符来实现 class Stack { public: //1.成…...

杨校老师课堂之信息学奥赛结构体操作使用经典题集锦汇总

C基础:结构体数组综合训练 员工信息处理系统题目描述输入描述输出描述解题思路参考代码 员工信息处理系统 题目描述 在一家企业中&#xff0c;员工信息的准确性和时效性是日常人事管理工作的关键。由于企业员工数量众多&#xff0c;手动统计与更新员工信息不仅耗费大量时间&a…...

8. Flink-CDC

1. Flink-CDC的介绍 Flink-cdc主要是用来同步数据库中的数据&#xff0c;它的主要优势在于基于Flink框架直接用Flink Stream Api 或Flink SQL 直接编程&#xff0c;不需要引入第三方组件 2.Flink-CDC的使用 Flink-cdc在使用上需要注意的点 注意Flink-cdc在2.1版本之前需要导…...

Windows 权限结构和原理:深入浅出

一、什么是权限&#xff1f; 权限&#xff0c;是指在操作系统或应用程序中&#xff0c;某个对象&#xff08;如用户、程序、设备等&#xff09;对特定资源的可操作范围。具体来说&#xff0c;权限控制了一个主体&#xff08;通常是用户或应用程序&#xff09;对某个资源&#…...