
该错误源于 python 3.12 与 dm-tree、keras 及 tensorflow 当前版本不兼容,导致 wheel 构建失败;根本解决方案是降级至 python 3.11。
当你在安装 Keras(尤其是通过 pip install keras 或基于 pyproject.toml 的现代构建流程)时遇到如下错误:
ERROR: Failed building wheel for dm-tree ERROR: Could not build wheels for dm-tree, which is required to install pyproject.toml-based projects
这并非网络或权限问题,而是底层依赖 dm-tree 的编译兼容性问题。dm-tree 是 DeepMind 开发的高效树结构操作库,被 Keras(特别是 Keras 3.x)和部分 TensorFlow 生态工具链所依赖。其当前(截至 2024 年中)发布的稳定版本 尚未提供对 Python 3.12 的预编译 wheel,且源码编译需匹配的 C++ 工具链与 NumPy/Cython 环境,极易因 ABI 不兼容而失败。
✅ 正确且最可靠的解决方案是:切换至 Python 3.11
✅ 推荐操作步骤(以 conda 为例):
# 创建独立的 Python 3.11 环境(推荐,避免污染全局环境) conda create -n keras-env python=3.11 conda activate keras-env # 升级 pip 和构建工具(确保兼容性) pip install --upgrade pip setuptools wheel # 安装 Keras(自动解析兼容依赖) pip install keras
? 若使用 pyenv / system Python:
# 安装 Python 3.11(如未安装) pyenv install 3.11.9 pyenv local 3.11.9 # 设置当前目录为 3.11 # 验证 python --version # 应输出 Python 3.11.9 pip install keras
⚠️ 注意事项:
立即学习“Python免费学习笔记(深入)”;
- 不要尝试强制用 --no-binary dm-tree 编译源码——这通常会因缺失 pybind11、C++17 支持或 NumPy 头文件而报更复杂的错误;
- TensorFlow 同样暂未正式支持 Python 3.12(官方支持列表见 TensorFlow GitHub releases),因此混用将引发连锁兼容问题;
- dm-tree 的 Python 3.12 支持已在 GitHub issue #156 中跟踪,但稳定版 wheel 尚未发布,不建议在生产环境中等待。
? 总结:这不是配置错误,而是生态适配的时间差问题。坚持使用 Python 3.11 是目前唯一零风险、开箱即用的解决方案。待 Keras 3.4+、TensorFlow 2.17+ 及 dm-tree 0.1.9+ 官方宣布 Python 3.12 全面支持后,再平滑升级。










