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+,保留更简洁的 | 语法。
相关推荐
紫丁香4 分钟前
pytest_自动化测试5
python·功能测试·单元测试·集成测试·pytest
姚青&6 分钟前
Pytest fixture 参数化(params 参数)
开发语言·python·pytest
2301_793804697 分钟前
深入理解Python的if __name__ == ‘__main__‘
jvm·数据库·python
qyzm8 分钟前
牛客周赛 Round 136
数据结构·python·算法
紫檀香8 分钟前
Alembic入门教程
后端·python
2401_8331977310 分钟前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
wayz1112 分钟前
DuckDB 完全指南:从入门到精通
python·金融·量化交易
暮冬-  Gentle°14 分钟前
用Python批量处理Excel和CSV文件
jvm·数据库·python
m0_7369142215 分钟前
服务器上pip install spacy卡住解决方法
开发语言·python
小陈工20 分钟前
2026年3月22日技术资讯洞察:数据库优化进入预测时代,网络安全威胁全面升级
java·开发语言·数据库·python·安全·web安全·django