@difizen/vscode-python-extension
v1.0.5
Published
An API facade for the Python extension in VS Code
Downloads
2
Readme
Python extension's API
This npm module implements an API facade for the Python extension in VS Code.
Example
First we need to define a package.json
for the extension that wants to use the API:
{
"name": "...",
...
// depend on the Python extension
"extensionDependencies": [
"ms-python.python"
],
// Depend on the Python extension facade npm module to get easier API access to the
// core extension.
"dependencies": {
"@vscode/python-extension": "...",
"@types/vscode": "..."
},
}
Update "@types/vscode"
to a recent version of VS Code, say "^1.81.0"
for VS Code version "1.81"
, in case there are any conflicts.
The actual source code to get the active environment to run some script could look like this:
// Import the API
import { PythonExtension } from '@vscode/python-extension';
...
// Load the Python extension API
const pythonApi: PythonExtension = await PythonExtension.api();
// This will return something like /usr/bin/python
const environmentPath = pythonApi.environments.getActiveEnvironmentPath();
// `environmentPath.path` carries the value of the setting. Note that this path may point to a folder and not the
// python binary. Depends entirely on how the env was created.
// E.g., `conda create -n myenv python` ensures the env has a python binary
// `conda create -n myenv` does not include a python binary.
// Also, the path specified may not be valid, use the following to get complete details for this environment if
// need be.
const environment = await pythonApi.environments.resolveEnvironment(environmentPath);
if (environment) {
// run your script here.
}
Check out the wiki for many more examples and usage.