powershell无法执行conda activate
问题描述
当我在vscode的终端执行conda activate env_name
时,会得到下面的报错:
usage: conda-script.py [-h] [--no-plugins] [-V] COMMAND ...
conda-script.py: error: argument COMMAND: invalid choice: 'activate' (choose from 'clean', 'compare', 'config', 'create', 'info', 'init', 'install', 'list', 'notices', 'package', 'remove', 'uninstall', 'rename', 'run', 'search', 'update', 'upgrade', 'build', 'convert', 'debug', 'develop', 'doctor', 'index', 'inspect', 'metapackage', 'render', 'skeleton', 'env', 'server', 'content-trust', 'pack', 'verify', 'token', 'repo')
它告诉我,没有activate
这个指令。
尝试解决
首先,我检查了我的系统路径,确定anaconda的系统路径均被正确设置了;而且我注意到系统路径下包含一个批处理文件...\Anaconda\Scripts\activate.bat
,我猜测激活环境应该就是通过执行这个脚本实现的。
我重新打开了一个powershell
窗口,准备试试能否通过直接执行activate.bat
激活环境,这时我注意到每次打开powershell都会出现但我此前都忽略掉的消息:
. : 无法加载文件 C:\Users\18562\Documents\WindowsPowerShell\profile.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参
阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
...
真相大白了,powershell默认的脚本执行策略是Restricted
,也就是不允许运行任何脚本。
解除powershell脚本运行限制
以管理员身份运行powershell,执行Get-ExecutionPolicy -List
查看当前执行策略,我得到的是:
Scope ExecutionPolicy
----- ---------------
MachinePolicy Undefined
UserPolicy Undefined
Process Undefined
CurrentUser Undefined
LocalMachine Undefined
这代表,我当前的执行策略均是未定义
,也就是默认的不允许执行。
执行Set-ExecutionPolicy RemoteSigned -Scope CurrentUser
,将当前用户的脚本执行策略修改为RemoteSigned
,就可以运行本地脚本了。
各种执行策略简要概述如下:
Restricted
:这是默认设置,不允许运行任何 PowerShell 脚本。AllSigned
:只允许运行经过数字签名的脚本。RemoteSigned
:允许运行本地创建的脚本。从 Internet 下载的脚本必须有一个数字签名才能运行。Unrestricted
:允许运行所有脚本。
重启一个powershell窗口,现在的提示行为(base) PS C:\Users\user_name\Desktop>
,左侧可以显示当前的conda环境名称了。而且conda activate env_name
指令也可以正常执行了。