目录
  • vscode下powershell终端进入python虚拟环境venv
  • python虚拟环境venv的日常使用
    • 虚拟环境venv介绍
    • 基本使用方法
    • 激活进入虚拟环境
  • 总结

    vscode下powershell终端进入python虚拟环境venv

    vscode在python程序目录下执行终端命令venv创建python虚拟环境,也就是将python的工作环境打包到当前目录下。

    > python -m venv venv

    接着我们就可以看到自动生成了一个venv的目录,里面其实就是python的各种执行程序。

    然后我们要在终端下进入这个venv的环境,之后使用pip安装的各种模块都会放在这个目录下,而不是本机python的安装目录。

    如何解决vscode下powershell终端进入python虚拟环境venv问题

    这样的好处就是,之后pyinstaller生成exe方便,不会造成系统中的模块太多,占地大。

    如果你设置了终端是cmd.exe,那么接着我们执行activate.bat

    如果你设置的是pwsh.exe,即powershell,那么我们要执行的是Activate.ps1

    • 第一种情况好说,直接执行后就可以了。
    • 第二种情况,就需要先给powershell设置执行脚本的权限。

    在终端下执行以下命令:

    > pwsh.exe -ExecutionPolicy AllSigned

    出现了这样的选择提示:可以选R和A,我选A了。

    如何解决vscode下powershell终端进入python虚拟环境venv问题

    接着,就可以进入venv的子终端环境中了,前面加了个(venv )。

    (venv) PS F:\PyCharmProject\togatest> 

    现在,再使用pip install xxxx,安装的模块包就会安装在当前目录下了。

    python虚拟环境venv的日常使用

    虚拟环境venv介绍

    官方文档

    官方介绍:

    venv 模块支持使用自己的站点目录创建轻量级“虚拟环境”,可选择与系统站点目录隔离。

    每个虚拟环境都有自己的 Python 二进制文件(与用于创建此环境的二进制文件的版本相匹配),并且可以在其站点目录中拥有自己独立的已安装 Python 软件包集。

    个人需求、理解和使用场景:

    • 在同一台机器上运行的python项目文件需要不同的特定python版本,比如python2项目和python3项目
    • 在编写一些项目时,避免其他项目的模块或者配置的干扰,独立出一个单独的python环境(相当于在一台纯净的机器上重新安装了python一样)
    • 防止莫名的报错!(个人体会最深,因为刚开始用python时明明都用的好好的,但是在同一个解释器环境下安装的模块多了,就容易报一些莫名其妙的错误,而且代码并没有错误,很大原因就是模块引用之间的冲突,例如我之前在用多线程时,经常报错 json 模块没有 loads 方法,后来才知道是环境问题)

    基本使用方法

    创建虚拟环境

    linux环境:

    python3 -m venv /path/to/new/virtual/environment

    运行此命令将创建目标目录(父目录若不存在也将创建),并放置一个 pyvenv.cfg 文件在其中,文件中有一个 home 键,它的值指向运行此命令的 Python 安装(目标目录的常用名称是 .venv)。

    它还会创建一个 bin 子目录(在 Windows 上是 Scripts),其中包含 Python 二进制文件的副本或符号链接(视创建环境时使用的平台或参数而定)。

    它还会创建一个(初始为空的) lib/pythonX.Y/site-packages 子目录(在 Windows 上是 Lib\site-packages)。

    如果指定了一个现有的目录,这个目录就将被重新使用。

    win环境:

    python -m venv \path\to\myenv

    激活进入虚拟环境

    • 进入到对应项目目录下的:\venv\Scripts
    • 然后打开命令行输入

    activate

    • 然后在命令行的盘符前面就可以看到多了 (venv) 字符,代表成功激活虚拟环境

    虚拟环境是一个 Python 环境,安装到其中的 Python 解释器、库和脚本与其他虚拟环境中的内容是隔离的,且(默认)与“系统级” Python(操作系统的一部分)中安装的库是隔离的。

    虚拟环境是一个目录树,其中包含 Python 可执行文件和其他文件,其他文件指示了这是一个是虚拟环境。

    常用安装工具如 setuptools 和 pip 可以在虚拟环境中按预期工作。换句话说,当虚拟环境被激活,它们就会将 Python 软件包安装到虚拟环境中,无需明确指示。

    当虚拟环境被激活(即虚拟环境的 Python 解释器正在运行),属性 sys.prefix 和 sys.exec_prefix 指向的是虚拟环境的基础目录,而 sys.base_prefix 和 sys.base_exec_prefix 指向非虚拟环境的 Python 安装,即曾用于创建虚拟环境的那个 Python 安装。如果虚拟环境没有被激活,则 sys.prefix 与 sys.base_prefix 相同,且 sys.exec_prefix 与 sys.base_exec_prefix 相同(它们均指向非虚拟环境的 Python 安装)。

    当虚拟环境被激活,所有 distutils 配置文件中更改安装路径的选项都会被忽略,以防止无意中将项目安装在虚拟环境之外。

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。