news 2026/4/16 16:49:51

解决TypeError: unsupported operand type(s) for |: ‘type‘ and ‘type‘

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
解决TypeError: unsupported operand type(s) for |: ‘type‘ and ‘type‘

这个错误是因为在Python 3.9及以下版本中,类型注解不支持使用"|"来联合类型。在Python 3.10及以上版本中才支持这种写法。

解决方案有两种:

  1. 升级Python到3.10或以上版本。(可能会涉及该一系列的依赖,可能要重新配置环境)

  2. 修改DINOv2的源代码,将类型注解中的"|"改为使用"Optional"或"Union"。

成功解决,但有一堆,提供一个专门的修复脚本来批量修复这些问题

# fix_dinov2_type_hints.py import os import re def fix_type_hints_in_file(file_path): """修复单个文件中的类型注解语法""" with open(file_path, 'r', encoding='utf-8') as f: content = f.read() # 备份原始内容 original_content = content # 修复所有 "type | None" 语法 content = re.sub(r'\bfloat\s*\|\s*None\b', 'Optional[float]', content) content = re.sub(r'\bint\s*\|\s*None\b', 'Optional[int]', content) content = re.sub(r'\bbool\s*\|\s*None\b', 'Optional[bool]', content) content = re.sub(r'\bstr\s*\|\s*None\b', 'Optional[str]', content) content = re.sub(r'\btorch\.Tensor\s*\|\s*None\b', 'Optional[torch.Tensor]', content) # 修复其他可能的类型联合语法(针对Python 3.10+) content = re.sub(r'\bfloat\s*\|\s*int\b', 'Union[float, int]', content) content = re.sub(r'\bint\s*\|\s*float\b', 'Union[int, float]', content) # 检查是否需要添加导入 if 'Optional' in content and 'from typing import Optional' not in content: # 在文件顶部添加导入 lines = content.split('\n') for i, line in enumerate(lines): if line.startswith('import ') or line.startswith('from ') or line.strip() == '': continue else: # 在第一个非导入/空行前插入 lines.insert(i, 'from typing import Optional, Union') break content = '\n'.join(lines) # 如果内容有变化,保存文件 if content != original_content: with open(file_path, 'w', encoding='utf-8') as f: f.write(content) print(f"已修复: {file_path}") return True return False def find_and_fix_dinov2_files(): """查找并修复DINOv2的所有Python文件""" import torch.hub hub_dir = torch.hub.get_dir() dinov2_path = os.path.join(hub_dir, 'facebookresearch_dinov2_main') if not os.path.exists(dinov2_path): print(f"未找到DINOv2路径: {dinov2_path}") return print(f"正在修复DINOv2文件在: {dinov2_path}") # 修复所有.py文件 for root, dirs, files in os.walk(dinov2_path): for file in files: if file.endswith('.py'): file_path = os.path.join(root, file) fix_type_hints_in_file(file_path) print("修复完成!") if __name__ == "__main__": find_and_fix_dinov2_files()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 1:57:12

AI如何优化软件卸载体验?Geek Uninstaller的智能分析

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个基于AI的软件卸载分析工具,能够自动检测Windows系统中安装的应用程序,并分析其关联的文件、注册表项和后台服务。要求:1) 使用机器学习…

作者头像 李华
网站建设 2026/4/16 14:04:10

零基础实现第一个DeepSORT项目:从安装到运行

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 生成一个极简版DeepSORT入门项目,要求:1. 使用预训练模型(不需训练);2. 依赖项不超过5个;3. 包含10行以内的…

作者头像 李华
网站建设 2026/4/16 14:30:05

1小时快速验证TRADINGAGENT想法的5种方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个TRADINGAGENT快速原型模板,包含:1. 可配置的策略参数界面;2. 集成数据API和模拟交易引擎;3. 即时可视化回测结果&#xff1…

作者头像 李华
网站建设 2026/4/11 2:50:33

Qwen2.5-7B知识蒸馏实验:云端GPU弹性使用,论文复现不卡顿

Qwen2.5-7B知识蒸馏实验:云端GPU弹性使用,论文复现不卡顿 1. 为什么需要云端GPU进行知识蒸馏实验 知识蒸馏是一种将大模型(教师模型)的知识迁移到小模型(学生模型)的技术,广泛应用于模型压缩和…

作者头像 李华
网站建设 2026/4/16 11:00:42

Python+Vue的医院挂号预约系统 Pycharm django flask

收藏关注不迷路!!需要的小伙伴可以发链接或者截图给我 项目介绍 随着社会的快速发展和人口老龄化的加剧,医疗服务需求不断增长,医院面临着前所未有的压力。传统的现场挂号方式因其效率低下、耗时耗力等弊端,已无法满足…

作者头像 李华