喜讯!TCMS 官网正式上线!一站式提供企业级定制研发、App 小程序开发、AI 与区块链等全栈软件服务,助力多行业数智转型,欢迎致电:13888011868 QQ 932256355 洽谈合作!
本文记录一次 macOS 下 pyenv 安装 Python 3.13 失败的完整排障过程,问题根源为全局启用 LLVM clang-21 导致编译器不兼容。提供优雅且不破坏原有环境的解决方案:默认保留新版 clang,仅在编译 Python 时临时切回系统编译器,兼顾日常开发与 Python 多版本管理,适合使用 pyenv、自定义编译器的开发者参考。

在用 pyenv 安装 Python 3.13 时,突然遇到经典报错:configure: error: C compiler cannot create executables,原本正常的环境一夜之间编译失败。排查后发现,问题根源是全局启用了 clang-21,与 Python 编译环境产生冲突。
本文整理了「默认保留 clang-21、仅按需切回系统编译器」的优雅方案,既不改变日常开发习惯,又能一键解决 pyenv 编译问题。
执行 pyenv install 3.13 直接报错:
BUILD FAILED (OS X 12.7.4 using python-build 2.6.19-7-g48cb1b8a)
...
checking for gcc... /opt/local/libexec/llvm-21/bin/clang
checking whether the C compiler works... no
configure: error: C compiler cannot create executables
安装 LLVM 21 后全局配置了编译器环境变量,导致 pyenv 编译 Python 时强制使用不兼容的 clang-21,而非系统自带的 clang。
# 全局默认启用 clang-21 下面的clang是使用 sudo port install clang-21安装的路径,需要根据你自己的情况调整
export PATH="/opt/local/libexec/llvm-21/bin:$PATH"
export LDFLAGS="-L/opt/local/lib -L/opt/local/libexec/llvm-21/lib ${LDFLAGS}"
export CPPFLAGS="-I/opt/local/include -I/opt/local/libexec/llvm-21/include ${CPPFLAGS}"
export CC="/opt/local/libexec/llvm-21/bin/clang"
export CXX="/opt/local/libexec/llvm-21/bin/clang++"
# 临时切回系统 clang 的别名(在需要使用系统默认clang时使用,如 pyenv install xxx)
alias use-system-clang='
export CC=/usr/bin/clang
export CXX=/usr/bin/clang++
echo "✅ 已临时切换到系统 clang(新开终端自动恢复 clang-21)"
'
# pyenv install 快捷命令, 默认使用系统clang
alias pyenv-install='
use-system-clang && \
pyenv install $1 && \
echo "✅ Python $1 安装完成"
'
生效配置:
source ~/.zshrc # 或者bash 执行 source ~/.bash_profile`
use-system-clang && pyenv install 3.13.11(或懒人命令 pyenv-install 3.13.11)# 全局切换到 3.13.11
pyenv global 3.13.11
# 验证
python --version # 输出 Python 3.13.11
echo $CC 是否为非系统编译器这个方案的核心是「最小侵入式修改」:默认保留你习惯的 clang-21 环境,仅在需要安装 Python 时临时切换编译器,既解决了编译冲突问题,又完全不改变日常开发流程,是兼顾「自定义编译器使用」和「pyenv 正常工作」的最优解。