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+,保留更简洁的 | 语法。
相关推荐
用户8356290780511 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户8356290780511 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生9 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师10 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码10 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf10 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent1 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6251 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python