Python的管道符(|)联合类型语法糖

python 复制代码
def create_access_token(data: dict, expires_delta: timedelta | None = None) -> str:
    to_encode = data.copy()
    expire = datetime.now(timezone.utc) + (
        expires_delta
        if expires_delta
        else timedelta(minutes=settings.access_token_expire_minutes)
    )
    to_encode.update({"exp": expire})
    return jwt.encode(to_encode, settings.jwt_secret_key, algorithm=settings.jwt_algorithm)

代码运行报错:

def create_access_token(data: dict, expires_delta: timedelta | None = None) -> str: TypeError: unsupported operand type(s) for |: 'type' and 'NoneType'

问题分析

timedelta | None 是 Python 3.10 才引入的管道符(|)联合类型语法糖 ,如果你的 Python 版本低于 3.10,解释器会把 | 当成普通的运算符,试图计算 type(timedelta)NoneType 的 "或运算",这显然是不支持的,因此抛出 TypeError

解决方案

只需要把新的联合类型写法改成兼容低版本 Python 的标准写法即可,有两种方式:

方式 1:使用 Union 类型(兼容所有 Python 3 版本)

这是最通用的写法,需要先从 typing 模块导入 Union

python 复制代码
from datetime import datetime, timedelta, timezone
from typing import Union  # 导入Union类型
import jwt
# 假设你的settings模块是这样的,需根据实际情况调整
class Settings:
    access_token_expire_minutes = 30
    jwt_secret_key = "your-secret-key-here"
    jwt_algorithm = "HS256"

settings = Settings()

def create_access_token(data: dict, expires_delta: Union[timedelta, None] = None) -> str:
    to_encode = data.copy()
    expire = datetime.now(timezone.utc) + (
        expires_delta
        if expires_delta
        else timedelta(minutes=settings.access_token_expire_minutes)
    )
    to_encode.update({"exp": expire})
    return jwt.encode(to_encode, settings.jwt_secret_key, algorithm=settings.jwt_algorithm)

# 测试代码(可选)
if __name__ == "__main__":
    token = create_access_token({"sub": "user123"})
    print("生成的Token:", token)

方式 2:升级 Python 到 3.10+(推荐长期方案)

如果你的项目环境允许,直接把 Python 版本升级到 3.10 或更高,就可以直接使用 timedelta | None 的写法,无需修改代码。

总结

  1. 报错根源:Python 版本 < 3.10 不支持 | 联合类型语法,将其识别为非法运算符。
  2. 快速修复:导入 typing.Union,用 Union[timedelta, None] 替代 timedelta | None
  3. 长期方案:升级 Python 到 3.10+,保留更简洁的 | 语法。
相关推荐
forEverPlume43 分钟前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
Aleeeeex1 小时前
RAG 那点事:从 8 份企业文档到能用的问答系统,全过程拆给你看
人工智能·python·ai编程
2301_809204701 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
2301_800976932 小时前
正则表达式
开发语言·python·正则表达式
码界奇点2 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
AI木马人2 小时前
1.人工智能实战:大模型推理接口响应慢?从模型加载到 FastAPI 部署的完整优化方案
人工智能·python·fastapi
青少儿编程课堂3 小时前
2026青少儿信息素养大赛备赛指南!Python/Scratch/C++备考要点
开发语言·c++·python
用户8356290780513 小时前
使用 Python 设置 Excel 数据验证
后端·python
Nick_zcy3 小时前
小说在线阅读网站和小说管理系统 · 功能全解析
java·后端·python·springboot·ruoyi
*Lisen3 小时前
从零手写 FlashAttention(PyTorch实现 + 原理推导)
人工智能·pytorch·python