By default the extension uses the Python interpreter available in the current path. You could always change this by specifying the path to the interpreter in the user or worksapce settings.
Configuring the extension to use a particular interpreter is now easy.
All you now need to do is make use of the command Select Workspace Interpreter
from the command palette and select an interpreter from the list.
If the interpreter you are looking for isn’t listed here, then please proceed to the next section and enter it manually.
Python Version used for Intellisense, Autocomplete, Linting, Formatting, etc
The same python interpreter is used for intellisense, autocomplete, linting, formatting, etc. (everything other than debugging). The standard interpreter used is the first “python” interpreter encountered in the current path.
If a specific version is to be used, then configure the path to the python interpreter in the User or Workspace Settings file (settings.json) as follows.
Ensure to specify the fully qualified name of the python executable (Mac and Linux supported).
"python.pythonPath": "c:/python27/python.exe"
There are two approaches to to getting this extension working in a particular Virtual Environment.
Option 1: Ensure the path to the python interpreter is set in python.pythonPath as defined previously.
Note: Do remember to configure the pythonPath in launch.json as well.
{
"python.pythonPath": "/home/xxx/dev/ala/venv/bin/python"
}
Finally, restart VS Code, necessary for intellisense to work (future release will not require a restart)
Ensure the libraries/modules you plan on using for linting are also installed within this virtual environment.
Option 2: Activate the Virtual Environment from your Terminal/Command Window and then launch VS Code.
(venv) ter@minal:~$ code .
Details on configuration settings for debugging can be found here Debugging.
Configuring the version of the python executable is no longer necessary.
Provided the setting python.pythonPath
in settings.json (see above) has been configured correctly, the debugger will use this same setting.
This is made possible by setting the value of the pythonPath setting to ${config.python.pythonPath}
. I.e. the debugger merely references the pythonPath setting from the settings.json file.
{
"name": "Python",
"type": "python",
"request": "launch",
"stopOnEntry": true,
"program": "${file}",
"pythonPath": "${config.python.pythonPath}",
"debugOptions": [
"WaitOnAbnormalExit",
"WaitOnNormalExit",
"RedirectOutput"
]
}
Unfortunately use of relative paths when configuring the interpreter in settings.json will not work with the debugger. Hence the solution is to provide the fully qualified path.
This could be achieved with the use of simple variables such as the following:
Where ${workspaceRoot}
resolves to the current work space (project) directory.
{
"python.pythonPath": "${workspaceRoot}/venv/bin/python"
}
Similar to the use of ${workspaceRoot}
, environment variables could be used in configuring the path to the python interpreter.
Where ${env.PYTHONPATH}
resolves to the value of the environment variable xyz.
{
"python.pythonPath": "${env.PYTHONPATH}/venv/bin/python"
}
By default the extension uses the Python interpreter available in the current path. You could always change this by specifying the path to the interpreter in the user or worksapce settings.
Configuring the extension to use a particular interpreter is now easy.
All you now need to do is make use of the command Select Workspace Interpreter
from the command palette and select an interpreter from the list.
If the interpreter you are looking for isn’t listed here, then please proceed to the next section and enter it manually.
Python Version used for Intellisense, Autocomplete, Linting, Formatting, etc
The same python interpreter is used for intellisense, autocomplete, linting, formatting, etc. (everything other than debugging). The standard interpreter used is the first “python” interpreter encountered in the current path.
If a specific version is to be used, then configure the path to the python interpreter in the User or Workspace Settings file (settings.json) as follows.
Ensure to specify the fully qualified name of the python executable (Mac and Linux supported).
"python.pythonPath": "c:/python27/python.exe"
There are two approaches to to getting this extension working in a particular Virtual Environment.
Option 1: Ensure the path to the python interpreter is set in python.pythonPath as defined previously.
Note: Do remember to configure the pythonPath in launch.json as well.
{
"python.pythonPath": "/home/xxx/dev/ala/venv/bin/python"
}
Finally, restart VS Code, necessary for intellisense to work (future release will not require a restart)
Ensure the libraries/modules you plan on using for linting are also installed within this virtual environment.
Option 2: Activate the Virtual Environment from your Terminal/Command Window and then launch VS Code.
(venv) ter@minal:~$ code .
Details on configuration settings for debugging can be found here Debugging.
Configuring the version of the python executable is no longer necessary.
Provided the setting python.pythonPath
in settings.json (see above) has been configured correctly, the debugger will use this same setting.
This is made possible by setting the value of the pythonPath setting to ${config.python.pythonPath}
. I.e. the debugger merely references the pythonPath setting from the settings.json file.
{
"name": "Python",
"type": "python",
"request": "launch",
"stopOnEntry": true,
"program": "${file}",
"pythonPath": "${config.python.pythonPath}",
"debugOptions": [
"WaitOnAbnormalExit",
"WaitOnNormalExit",
"RedirectOutput"
]
}
Unfortunately use of relative paths when configuring the interpreter in settings.json will not work with the debugger. Hence the solution is to provide the fully qualified path.
This could be achieved with the use of simple variables such as the following:
Where ${workspaceRoot}
resolves to the current work space (project) directory.
{
"python.pythonPath": "${workspaceRoot}/venv/bin/python"
}
Similar to the use of ${workspaceRoot}
, environment variables could be used in configuring the path to the python interpreter.
Where ${env.PYTHONPATH}
resolves to the value of the environment variable xyz.
{
"python.pythonPath": "${env.PYTHONPATH}/venv/bin/python"
}