typing.Union` 标注一多种变量类型

2023-11-01 13:52

本文主要是介绍typing.Union` 标注一多种变量类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

typing.Union 标注一多种变量类型

typing.Union 是Python typing 模块中用于标注一个变量可以是多种类型之一的类型提示。在Python 3.10版本及以后,推荐使用 | 运算符代替 Union。不过,在详细介绍 Union 的用法前,值得注意的是在大多数情况下,如果一个变量可以是 None 或其他类型,你应该使用 Optional 类型,它是 Union 的一个特殊情况。

作为函数参数

当你有一个函数,其参数可以是多种类型中的一种时,你可以使用 Union 来标注这个参数。

from typing import Uniondef process_data(data: Union[str, bytes]) -> None:if isinstance(data, str):print("Data is a string:", data)else:print("Data is bytes:", data.decode('utf-8'))

在这个例子中,process_data 函数接受一个参数 data,它可以是 strbytes 类型。函数内部使用 isinstance 函数来检查 data 的类型,并据此执行不同的操作。

作为返回值

Union 也可以用来标注一个函数的返回值可能是多种类型中的一种。

from typing import Uniondef get_data(flag: bool) -> Union[str, bytes]:if flag:return "Hello, world!"else:return b"Hello, world!"

在这个例子中,get_data 函数根据布尔参数 flag 返回一个 strbytes 类型的值。

使用 | 运算符

从Python 3.10开始,你可以使用 | 运算符来代替 Union

def process_data(data: str | bytes) -> None:if isinstance(data, str):print("Data is a string:", data)else:print("Data is bytes:", data.decode('utf-8'))def get_data(flag: bool) -> str | bytes:if flag:return "Hello, world!"else:return b"Hello, world!"

在这个例子中,process_dataget_data 函数的类型标注方式与之前使用 Union 的例子相同,但更为简洁。

注意事项

  • 使用 Union| 运算符时,应确保你的代码能正确处理所有可能的类型。
  • 对于可以是 None 的类型,推荐使用 Optional[Type],这等同于 Union[Type, None]
  • 使用 Union 时,避免将太多的类型组合在一起,这会使代码更难以阅读和维护。如果一个变量可以有许多不同的类型,考虑是否可以通过重构代码或使用类和继承来简化类型关系。
  • 在使用 Union| 运算符时,确保你的代码在运行时也能正确处理所有声明的类型。这可能涉及到运行时类型检查和适当的错误处理。

这篇关于typing.Union` 标注一多种变量类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323454

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

Mysql BLOB类型介绍

BLOB类型的字段用于存储二进制数据 在MySQL中,BLOB类型,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储的大小不同。 TinyBlob 最大 255 Blob 最大 65K MediumBlob 最大 16M LongBlob 最大 4G

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla