news 2026/5/11 16:24:31

typing和dataclass

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
typing和dataclass

typing模块里常用的类型注解工具,和 Python 3.9+ 原生类型的对应关系及用法如下,刚好能匹配你之前的答题系统场景:

typing类型Python 3.9+ 原生写法作用说明示例
List[T]list[T]标注元素类型为 T 的列表answers: list[SingleAnswer]
Dict[K, V]dict[K, V]标注键类型 K、值类型 V 的字典score: dict[str, int]
Tuple[T1, T2]tuple[T1, T2]标注固定长度和类型的元组q_and_a: tuple[int, str]
Set[T]set[T]标注元素类型为 T 的集合options: set[str]
Optional[T]`TNone`标注变量可以是 T 类型或 None`remark: strNone = None`
Union[T1, T2]`T1T2`标注变量可以是 T1 或 T2 类型`value: intstr`
Literal[val1, val2]Literal[val1, val2]标注变量只能是 val1、val2 等值option: Literal["A", "B", "C", "D"]
Callable[[ArgT], RetT]Callable[[ArgT], RetT]标注函数类型(参数类型 + 返回值类型)func: Callable[[int], bool]

补充说明

  1. Python 3.9 是个分水岭,之后可以直接用原生的list/dict代替List/Dict,但Literal/Callable这类特殊类型还是要从typing导入(Python 3.10+ 可从typingtypes导入)。
  2. 这些类型注解不影响代码运行,主要是给 IDE 做提示、给开发者看,搭配 Pydantic 时还能用来做数据校验。
# 导入dataclass装饰器 from dataclasses import dataclass # ==================== 普通 class 写法 ==================== class CommonProduct: """普通类,需要手动实现 __init__、__repr__、__eq__ 等魔法方法""" # 1. 手动写初始化方法,接收参数并赋值给实例属性 def __init__(self, name: str, price: float, stock: int): self.name = name self.price = price self.stock = stock # 2. 手动写 __repr__ 方法,控制实例打印时的输出格式(方便调试) def __repr__(self): return f"CommonProduct(name='{self.name}', price={self.price}, stock={self.stock})" # 3. 手动写 __eq__ 方法,定义两个实例的相等判断规则 def __eq__(self, other): # 先判断 other 是否是 CommonProduct 类型 if not isinstance(other, CommonProduct): return False # 当 name、price、stock 都相同时,两个实例才相等 return (self.name == other.name and self.price == other.price and self.stock == other.stock) # ==================== dataclass 写法 ==================== @dataclass # 装饰器自动生成 __init__、__repr__、__eq__ 等方法 class DataProduct: """dataclass 写法,无需手动编写魔法方法,只需定义字段和类型注解""" name: str # 商品名称 price: float # 商品价格 stock: int # 商品库存 # ==================== 测试对比 ==================== if __name__ == "__main__": # 1. 测试普通类 p1 = CommonProduct("T恤", 59.9, 100) p2 = CommonProduct("T恤", 59.9, 100) print("普通类实例打印:", p1) # 调用 __repr__ print("普通类实例相等判断:", p1 == p2) # 调用 __eq__,输出 True print("-" * 50) # 2. 测试 dataclass dp1 = DataProduct("牛仔裤", 129.9, 50) dp2 = DataProduct("牛仔裤", 129.9, 50) print("dataclass实例打印:", dp1) # 自动生成的 __repr__ print("dataclass实例相等判断:", dp1 == dp2) # 自动生成的 __eq__,输出 True

eq它的本质就是比对两个类的值是否相等,当然了只能比对整体,不能单个比对 就算一个不相等,它也是返回false repr它是默认会打印出你传入参数值 方便调试 dataclss会自动创建省得你手动 而且只要是传参的类都建议用dataclass 这样省去写__init__ repr就算地址不同 但是值相同就是一致的 但是他的只是属于类型提示 并不能校验 并不会报错 对于后端写api的建议使用pydantic他会校验传入的值 如果类型不对会进行报错

from pydantic import BaseModel, Field, ValidationError from typing import Literal # 方法1:用Literal直接限定只能是A、B、C、D class SingleAnswer(BaseModel): question_id: int option: Literal["A", "B", "C", "D"] # 只能选这四个选项 # 方法2:用正则表达式校验(适合更灵活的情况,比如允许小写a-d) class SingleAnswerWithRegex(BaseModel): question_id: int option: str = Field(pattern=r"^[A-Da-d]$") # 正则匹配A-D或a-d # 测试正确的情况 correct_ans = SingleAnswer(question_id=1, option="A") print(correct_ans) # 正常输出 # 测试错误的情况(选项为E) try: wrong_ans = SingleAnswer(question_id=2, option="E") except ValidationError as e: print(e) # 会提示选项必须是A、B、C、D中的一个
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 15:13:36

计数if|

lc25931.mask ll也会溢出 转vec bool2.sort pii(nums,idx) 后标记自身 &#xff06;左右一次遍历即可class Solution { typedef long long ll; public:long long findScore(vector<int>& nums) {ll ret 0;int n nums.size();if (n 1) return nums[0];vector<bo…

作者头像 李华
网站建设 2026/5/3 4:02:17

不用盯电脑!小红书多号定时发布 + 数据聚合攻略

“A号笔记刚编完&#xff0c;切B号时退错账号&#xff1b;盯C号数据入神&#xff0c;漏了D号私信&#xff1b;凌晨爬起来掐高峰发笔记&#xff0c;结果还发错号……” 这是小红书多号运营者的日常&#xff1a;多号布局本想放大收益&#xff0c;却一半精力耗在切号、查数据、盯…

作者头像 李华
网站建设 2026/5/10 8:35:58

PyMC终极指南:贝叶斯建模从入门到实战

PyMC终极指南&#xff1a;贝叶斯建模从入门到实战 【免费下载链接】pymc Python 中的贝叶斯建模和概率编程。 项目地址: https://gitcode.com/GitHub_Trending/py/pymc 还在为传统统计方法无法量化不确定性而困扰吗&#xff1f;想要通过概率编程轻松构建贝叶斯模型吗&am…

作者头像 李华
网站建设 2026/4/22 23:33:04

你的接口很好,但在使用者眼里,它可能只是个打不开的黑盒

有过"考古式开发"的经历吗&#xff1f;你接手了一个离职同事留下的老项目&#xff0c;或者在一个庞大的微服务群里找到了一个看似完美契合需求的内部接口。你满怀期待地点击文档链接&#xff0c;结果页面上只有冷冷清清的一行字&#xff1a;TODO: 待补充。你只能咬着…

作者头像 李华
网站建设 2026/5/7 22:08:50

BUYCOIN:当社区开始争夺交易时代的主导权

在加密行业里&#xff0c;有些创新依靠功能升级&#xff0c;有些依靠技术突破&#xff0c;而极少数会直接改变行业的权力结构。前两类会变成产品&#xff0c;后一类会变成时代。BUYCOIN 属于第三类。 它没有靠外部热点拉起声量&#xff0c;也不是从叙事中诞生的产物&#xff0c…

作者头像 李华
网站建设 2026/5/5 1:01:04

商场日常清洁应该配备怎样的洗地车以提升清洁效率和质量

商场日常清洁新趋势&#xff0c;洗地车的选择至关重要在商场的日常清洁中&#xff0c;适合的洗地车选择直接影响清洁效率与质量。现代商场面临的人流量大、地面面积广的问题&#xff0c;使得选用高效的清洁设备显得尤为重要。如今&#xff0c;“商场洗地车”不仅要求具备基本的…

作者头像 李华