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+,保留更简洁的 | 语法。
相关推荐
好家伙VCC19 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
前端玖耀里20 小时前
如何使用python的boto库和SES发送电子邮件?
python
serve the people20 小时前
python环境搭建 (十二) pydantic和pydantic-settings类型验证与解析
java·网络·python
小天源20 小时前
Error 1053 Error 1067 服务“启动后立即停止” Java / Python 程序无法后台运行 windows nssm注册器下载与报错处理
开发语言·windows·python·nssm·error 1053·error 1067
喵手20 小时前
Python爬虫实战:HTTP缓存系统深度实战 — ETag、Last-Modified与requests-cache完全指南(附SQLite持久化存储)!
爬虫·python·爬虫实战·http缓存·etag·零基础python爬虫教学·requests-cache
喵手20 小时前
Python爬虫实战:容器化与定时调度实战 - Docker + Cron + 日志轮转 + 失败重试完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·容器化·零基础python爬虫教学·csv导出·定时调度
2601_9491465321 小时前
Python语音通知接口接入教程:开发者快速集成AI语音API的脚本实现
人工智能·python·语音识别
寻梦csdn21 小时前
pycharm+miniconda兼容问题
ide·python·pycharm·conda
Java面试题总结1 天前
基于 Java 的 PDF 文本水印实现方案(iText7 示例)
java·python·pdf
不懒不懒1 天前
【决策树算法实战指南:从原理到Python实现】
python·决策树·id3·c4.5·catr