Mac 系统 Python 开发环境搭建:Pyenv + Virtualenv 图文完整方案

1、引言

1.1、Pyenv 简介

Pyenv 是一个用于管理多个 Python 版本的开源工具,允许你在同一台机器上轻松安装、切换和管理不同的 Python 版本,而不会产生冲突。最初由 Yoshinori Kawasaki 开发,现由 Python 社区维护,是 Mac 和 Linux 系统上最受欢迎的 Python 版本管理器之一。

核心功能
✅ 多版本共存

  • 安装任意版本的 Python(官方 CPython、PyPy、Jython 等)
  • 支持最新 dev 版本、历史旧版本、预发布版本

✅ 全局/局部版本切换

  • 全局版本:系统默认 Python 版本
  • 局部版本:为特定项目目录设置独立 Python 版本
  • Shell 临时版本:当前终端会话临时切换

✅ 版本隔离

  • 所有 Python 版本安装在用户目录下,不影响系统 Python
  • 无需 sudo 权限即可安装新版本
  • 彻底避免破坏系统依赖

✅ 插件生态

  • pyenv-virtualenv:集成虚拟环境管理
  • pyenv-update:一键更新 Pyenv 本身
  • pyenv-installer:简化安装流程

1.2、Virtualenv 简介

Virtualenv 是一个用于创建隔离 Python 环境的工具,它能为每个项目生成独立的虚拟环境,使不同项目的依赖包互不干扰。每个虚拟环境都是一个包含独立 Python 解释器、库和脚本的目录。由 Ian Bicking 创建,是 Python 生态中最经典、最轻量的虚拟环境管理工具,至今仍是许多开发者的首选方案。
核心功能
✅ 依赖隔离

  • 每个项目拥有独立的 site-packages 目录
  • 不同项目可使用相同包的不同版本(如 Django 3.2 vs 4.2)
  • 彻底解决"依赖地狱"问题

✅ 环境复制

  • 通过 requirements.txt 轻松复制环境配置
  • 支持跨平台、跨机器部署

✅ 轻量纯粹

  • 仅专注虚拟环境管理,功能单一
  • 不绑定 Python 版本管理
  • 速度快,占用资源少

✅ 灵活配置

  • 可选择继承或隔离系统全局包
  • 支持自定义虚拟环境目录位置

1.3、资源

Pyenv GItHub 地址
Virtualenv GitHub 地址
Virtualenv 官网地址

在这里插入图片描述

2、安装

2.1、Pyenv 安装(Git Clone 安装)

2.1.1、通过 Git 安装

# 克隆 pyenv 仓库到本地电脑指定目录git clone https://github.com/pyenv/pyenv.git /Users/woniu/GItHub/pyenv 

2.1.2、配置环境变量

# 配置环境变量(zsh 示例)echo'export PYENV_ROOT="/Users/woniu/GItHub/pyenv"'>> ~/.zshrc echo'export PATH="$PYENV_ROOT/bin:$PATH"'>> ~/.zshrc echo'export PATH="$PYENV_ROOT/shims:$PATH"'>> ~/.zshrc echo'eval "$(pyenv init -)"'>> ~/.zshrc # 使配置生效source ~/.zshrc 

2.1.3、验证安装

# 查看 pyenv 版本 pyenv --version

2.2、安装 pyenv-virtualenv 插件

2.2.1、克隆插件到 pyenv 插件目录

# 克隆插件到 pyenv 插件目录git clone https://github.com/pyenv/pyenv-virtualenv.git $(pyenv root)/plugins/pyenv-virtualenv 

命令解析

  • $(pyenv root) 自动获取 pyenv 安装目录
  • 插件必须安装在 pyenv/plugins/ 子目录下才能被识别

2.2.2、配置环境变量

# 配置环境变量(zsh 示例)echo'eval "$(pyenv virtualenv-init -)"'>> ~/.zshrc # 使配置生效source ~/.zshrc 

2.2.3、验证安装

# 检查插件是否被识别 pyenv help|grep virtualenv # 查看可用的 virtualenv 命令 pyenv virtualenv --help# 查看 virtualenv 插件版本 pyenv virtualenv --version

2.1、镜像加速

pyenv install 速度过慢,使用国内镜像加速

# 在 ~/.zshrc 或 ~/.bash_profile 中添加# 加速 GNU 包(解决 readline 下载慢)echo'export PYTHON_BUILD_MIRROR_URL="https://mirrors.huaweicloud.com/gnu/"'>> ~/.zshrc # 加速 Python 源码echo'export PYTHON_BUILD_PACKAGE_MIRROR_URL="https://mirrors.huaweicloud.com/python/"'>> ~/.zshrc # 跳过校验(解决镜像不一致问题)echo'export PYTHON_BUILD_MIRROR_URL_SKIP_CHECKSUM=1'>> ~/.zshrc # 使配置生效source ~/.zshrc # 验证两个变量echo"GNU镜像: $PYTHON_BUILD_MIRROR_URL"echo"Python镜像: $PYTHON_BUILD_PACKAGE_MIRROR_URL"

3、实战

3.1、Pyenv 基本使用命令

# 查看可安装的 Python 版本 pyenv install--list|grep"^ 3."# 安装指定版本 pyenv install3.11.8 pyenv install2.7.18 # 查看已安装 python 版本 pyenv versions # 设置全局默认版本 pyenv global 3.11.8 # 设置当前项目版本(创建 .python-version 文件)cd ~/myproject pyenv local2.7.18 # 查看 pyenv 当前版本 pyenv version # 查看 python 当前版本 python --version

3.2、Pyenv - Virtualenv 基本使用命令

# 查看所有虚拟环境 pyenv virtualenvs # 创建虚拟环境(基于指定 Python 版本) pyenv virtualenv 3.11.8 myproject-env # 删除虚拟环境 pyenv uninstall myproject-env # 或 pyenv virtualenv-delete myproject-env # 激活虚拟环境(自动切换 Python 版本) pyenv activate myproject-env # 退出虚拟环境 pyenv deactivate # 为项目目录设置本地虚拟环境(推荐) pyenv local myproject-env # 这会创建 .python-version 文件,进入目录时自动激活# 设置全局默认虚拟环境 pyenv global myproject-env # 查看虚拟环境所在路径 pyenv prefix myproject-env 

3.3、新项目配置流程

# 1. 安装所需 Python 版本 pyenv install3.11.6 # 2. 创建项目虚拟环境 pyenv virtualenv 3.11.6 myproject-env # 3. 进入项目目录并激活cd myproject pyenv local myproject-env # 验证:查看 Python 路径which python # 输出应为:~/.pyenv/versions/myproject-env/bin/python

3.4、虚拟环境中安装 Python 包

3.4.1、pip install 切换镜像源

1、快速解决(临时换源)

# 清华源(推荐) pip install-i https://pypi.tuna.tsinghua.edu.cn/simple requests # 阿里源 pip install-i https://mirrors.aliyun.com/pypi/simple/ pandas # 中科大源 pip install-i https://pypi.mirrors.ustc.edu.cn/simple/ numpy # 豆瓣源 pip install-i https://pypi.douban.com/simple/ django 

2、永久配置(命令行配置)

# 清华源 pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple # 验证配置 pip config list 

激活后,直接使用 pip 安装,无需 sudo:

# 安装单个包 pip install requests pandas numpy # 从 requirements.txt 批量安装 pip install-r requirements.txt # 指定版本安装 pip installdjango==4.2.7 # 卸载包 pip uninstall -ydjango==4.2.7 # 查看已安装的包 pip list # 查看某个包的详细信息 pip show requests # 以 requirements.txt 格式输出(适合导出) pip freeze > requirements.txt # 检查是否有可更新的包 pip list --outdated# 统计包的数量 pip list |wc-l

本文教程到此结束,祝愿小伙伴们在编程之旅中能够愉快地探索、学习、成长!

Read more

深入剖析:按下 F5 后,浏览器前端究竟发生了什么?

深入剖析:按下 F5 后,浏览器前端究竟发生了什么?

文章目录 * 概述 * 一、关键前提:三种导航方式的本质区别 * 二、核心概念:强缓存 vs 协商缓存 * 1. 强缓存(Strong Caching) * 2. 协商缓存(Revalidation Caching) * 三、F5 刷新全景流程图 * 四、F5 刷新的完整生命周期详解 * 阶段一:主文档(HTML)的缓存验证与获取 * 阶段二:HTML 解析与渲染流水线(Critical Rendering Path) * 阶段三:子资源(CSS/JS/IMG)的缓存处理 * 五、对比总结:F5 与其他操作的本质差异 * 六、给前端开发者的实践建议 * 七、结语 概述 在前端开发中,

By Ne0inhk

Webots R2023b 完整安装配置教程

Webots R2023b 完整安装配置教程 声明:本教程由豆包、ChatGPT等AI工具协助完成。 本教程讲解如何安装 Python3、包管理器 Micromamba、必要依赖包(如 opencv-python),以及 Webots 仿真软件,并完成 Micromamba Python 环境与 MATLAB 地址的配置,适用于 Windows、macOS 双系统。 一、前置说明 1. 适用场景:需要使用 Webots 进行仿真开发,同时依赖 Python 进行脚本编写、OpenCV 进行图像处理,通过 Micromamba 管理 Python 环境,并关联 MATLAB 路径用于联合开发。 2. 版本约定(兼容性最优): * Python:

By Ne0inhk
35道常见的前端vue面试题,零基础入门到精通,收藏这篇就够了

35道常见的前端vue面试题,零基础入门到精通,收藏这篇就够了

来源 | https://segmentfault.com/a/1190000021936876 今天这篇文章给大家分享一些常见的前端vue面试题。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 对于前端来说,尽管css、html、js是主要的基础知识,但是随着技术的不断发展,出现了很多优秀的mv*框架以及小程序框架。因此,对于前端开发者而言,需要对一些前端框架进行熟练掌握。这篇文章我们一起来聊一聊VUE及全家桶的常见面试问题。 1、请讲述下VUE的MVVM的理解? MVVM 是 Model-View-ViewModel的缩写,即将数据模型与数据表现层通过数据驱动进行分离,从而只需要关系数据模型的开发,而不需要考虑页面的表现,具体说来如下: Model代表数据模型:主要用于定义数据和操作的业务逻辑。 View代表页面展示组件(即dom展现形式):负责将数据模型转化成UI 展现出来。 ViewModel为model和view之间的桥梁:监听模型数据的改变和控制视图行为、处理用户交互。通过双向数据绑定把 View 层和 Model 层连接了起来,而View

By Ne0inhk
【前端实战】从 try-catch 回调到链式调用:一种更优雅的 async/await 错误处理方案

【前端实战】从 try-catch 回调到链式调用:一种更优雅的 async/await 错误处理方案

目录 【前端实战】从 try-catch 回调到链式调用:一种更优雅的 async/await 错误处理方案 一、问题背景:async/await 真的解决了一切麻烦吗? 二、真实业务场景下的痛点 1、错误需要“分阶段处理” 2、try-catch 的引入打破了 async/await 的链式范式 三、借鉴 Go、Rust 语言特性,错误也是一种结果 1、错误优先风格替代 try-catch 2、封装一个 safeAsync 工具函数 四、进阶版 safeAsync 函数设计 五、结语         作者:watermelo37         ZEEKLOG优质创作者、华为云云享专家、阿里云专家博主、腾讯云“

By Ne0inhk