This repository is for providing feedback and documentation on the Pylance language server extension in Visual Studio Code. You can use the repository to report issues or submit feature requests. The Pylance codebase is not open-source but you can contribute to Pyright to make improvements to the core typing engine that powers the Pylance experience.
Pylance is the default language support for Python in Visual Studio Code and is shipped as part of that extension as an optional dependency.
The Pylance name is a small ode to Monty Python’s Lancelot who was the first knight to answer the bridgekeeper’s questions in the Holy Grail.
Quick Start
Install the Python extension from the marketplace. Pylance will be installed as an optional extension.
Open a Python (.py) file and the Pylance extension will activate.
Note: If you’ve previously set a language server and want to try Pylance, make sure you’ve set "python.languageServer": "Default" or "Pylance" in your settings.json file using the text editor, or using the Settings Editor UI.
Features
Pylance provides some awesome features for Python 3, including:
Docstrings
Signature help, with type information
Parameter suggestions
Code completion
Auto-imports (as well as add and remove import code actions)
As-you-type reporting of code errors and warnings (diagnostics)
Pylance provides users with the ability to customize their Python language support via a host of settings which can either be placed in the settings.json file in your workspace, or edited through the Settings Editor UI.
Offers predefined configurations to help users optimize Pylance’s performance based on their development needs. It controls how many IntelliSense features Pylance provides, allowing you to choose between full language service functionality or a lightweight experience optimized for performance.
Default value: default
Available values:
light
default (default)
full
Description:
default: Provides a balanced experience with many useful features enabled by default. It ensures that the language server delivers sufficient functionality for most users without overloading the system. Advanced features can be enabled as needed, allowing for further customization at the cost of performance.
light: Designed for users seeking a lightweight, memory-efficient setup. This mode disables various features to make Pylance function more like a streamlined text editor. Ideal for those who do not require the full breadth of IntelliSense capabilities and prefer Pylance to be as resource-friendly as possible.
full: Designed for users seeking the most extensive feature set. This mode enables most of Pylance’s features, offering the richest IntelliSense experience. Ideal for those who want access to the full range of available functionality.
Individual settings can be configured to override the defaults set by languageServerMode.
Used to specify the level of type checking analysis performed.
Default: off.
Note that the value of this setting can be overridden by having a pyrightconfig.json or a pyproject.toml. For more information see this link.
Available values:
off: No type checking analysis is conducted; unresolved imports/variables diagnostics are produced.
basic: All rules from off + basic type checking rules.
standard: All rules from basic + standard type checking rules.
strict: All rules from standard + strict type checking rules.
You can refer to pyright documentation to reference the default type checking rules for each of the type checking modes.
Performance Consideration:
Setting python.analysis.typeCheckingMode to off can improve performance by disabling type checking analysis, which can be resource-intensive, especially in large codebases.
python.analysis.diagnosticMode
Used to allow a user to specify what files they want the language server to analyze to get problems flagged in their code.
Available values:
workspace
openFilesOnly (default)
Performance Consideration:
Setting python.analysis.diagnosticMode to openFilesOnly limits analysis to open files, improving performance by reducing the amount of code Pylance needs to process in large workspaces.
Paths of directories or files that should be included. If no paths are specified, Pylance defaults to the directory that contains workspace root. Paths may contain wildcard characters ** (a directory or multiple levels of directories), * (a sequence of zero or more characters), or ? (a single character).
Paths of directories or files that should not be included. These override the include directories, allowing specific subdirectories to be excluded. Note that files in the exclude paths may still be included in the analysis if they are referenced (imported) by source files that are not excluded. Paths may contain wildcard characters ** (a directory or multiple levels of directories), * (a sequence of zero or more characters), or ? (a single character). If no exclude paths are specified, Pylance automatically excludes the following: **/node_modules, **/__pycache__, .git and any virtual environment directories.
Default value: empty array (or ["**"] in light mode)
Performance Consideration:
Excluding unnecessary files or directories can significantly improve performance by reducing the scope of analysis. For example, setting python.analysis.exclude to ["**"] will exclude all files except those currently open, minimizing resource consumption.
Paths of directories or files whose diagnostic output (errors and warnings) should be suppressed even if they are an included file or within the transitive closure of an included file. Paths may contain wildcard characters ** (a directory or multiple levels of directories), * (a sequence of zero or more characters), or ? (a single character).
Default value: empty array
python.analysis.stubPath
Used to allow a user to specify a path to a directory that contains custom type stubs. Each package’s type stub file(s) are expected to be in its own subdirectory.
Default value: ./typings
python.analysis.autoSearchPaths
Used to automatically add search paths based on some predefined names (like src).
Used to parse the source code for a package when a typestub is not found.
Default value: true (or false in light mode)
Accepted values:
true (default)
false
Performance Consideration:
Setting python.analysis.useLibraryCodeForTypes to false can improve performance by preventing Pylance from parsing the source code of third-party libraries when type stubs are unavailable, thereby reducing resource usage.
Used to specify whether Pylance should index installed third party libraries and user files to improve features such as auto-import, add import, workspace symbols, etc.
Without indexing, auto-import, add import, and workspace symbols will have less information.
Default value: true (or false in light mode)
Available values:
true (default)
false
Performance Consideration:
Disabling indexing by setting python.analysis.indexing to false can improve performance by reducing resource consumption, especially in large projects, at the cost of making features like auto-imports and workspace symbol search find fewer symbols.
Maximum number of user files to index in the workspace. Indexing files is a performance-intensive task. Please use this setting to limit the number of files you want us to index. If you enter -1, we will index all files.
Default value: 2000 (or -1 for full mode)
Performance Consideration:
Increasing this number will cause Pylance to allocate more resources for user file indexing.
Used to override how many levels under installed packages to index on a per package basis. By default, only top-level modules are indexed (depth = 1). To index submodules, increase depth by 1 for each level of submodule you want to index.
{ "name": "package name (str)", "depth": "depth to scan (int)", "includeAllSymbols": "whether to include all symbols (bool)"}
If includeAllSymbols is set to false, only symbols in each package’s __all__ are included. When it’s set to true, Pylance will index every module/top level symbol declarations in the file.
Instead of relying on the shared stdlib.json indices for all Python versions, generate unique indices tailored to each workspace’s specific Python version and platform. This regeneration process will affect performance, unlike using the prebuilt stdlib indices.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
Performance Consideration:
Enabling this can impact performance by creating its own indices for standard libraries.
Used to control the offering of auto-imports in completions. This will impact number of items shown in the completion and performance.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
Performance Consideration:
Enabling python.analysis.autoImportCompletions can impact performance by increasing the number of completion items and resource usage. Disabling it can improve performance by reducing the computational overhead during code completion.
Show only direct dependencies declared in requirements.txt or pyproject.toml in auto import suggestions, if they exist. This only affects auto import for completions. The add import code action will continue to show all possible imports.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
python.analysis.importFormat
Defines the default format for import module.
Accepted values:
absolute (default)
relative
python.analysis.completeFunctionParens
Add parentheses to function completions.
Accepted values:
true
false (default)
Performance Consideration:
Disabling python.analysis.completeFunctionParens can slightly improve performance by reducing the overhead during code completion, though the impact is minimal.
python.analysis.inlayHints.variableTypes
Enable/disable inlay hints for variable types.
Accepted values:
true
false (default)
Performance Consideration:
Disabling inlay hints for variable types by setting python.analysis.inlayHints.variableTypes to false can improve performance by reducing the processing required to generate these hints, which can be beneficial in large codebases.
python.analysis.inlayHints.functionReturnTypes
Enable/disable inlay hints for function return types.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
Performance Consideration:
Disabling inlay hints for function return types can improve performance by reducing the overhead of generating these hints.
python.analysis.inlayHints.callArgumentNames
Enable/disable inlay hints for call argument names.
Accepted values:
off (default)
partial
all
Performance Consideration:
Setting python.analysis.inlayHints.callArgumentNames to off can improve performance by reducing the processing needed to display argument names during function calls.
python.analysis.inlayHints.pytestParameters
Enable/disable inlay hints for pytest function parameters.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
Example:
def test_foo(my_fixture): assert(my_fixture)
becomes
def test_foo(my_fixture: str): assert(my_fixture)
Performance Consideration:
Disabling inlay hints for pytest parameters can improve performance by reducing the overhead associated with generating these hints.
python.analysis.fixAll
The set of commands to run when doing a fixall.
Accepted values:
source.unusedImports
source.convertImportFormat
python.analysis.enablePytestSupport
Enable pytest goto def and inlay hint support for fixtures.
Default value: true (or false in light mode)
Accepted values:
true (default)
false
Performance Consideration:
Disabling pytest support by setting python.analysis.enablePytestSupport to false can improve performance by reducing the overhead associated with providing IntelliSense features for pytest fixtures.
python.analysis.autoFormatStrings
When typing a { in a string, automatically puts an f on the front of the string.
Accepted values:
true
false (default)
Performance Consideration:
Disabling python.analysis.autoFormatStrings can slightly improve performance by reducing the processing required during string formatting, though the impact is minimal.
python.analysis.nodeExecutable
Path to a node executable to use to run Pylance. If this value is empty, Pylance uses VS Code’s node executable. If set to auto, it will automatically download a version from nodejs
Set this value when you are having out of memory issues. Using a custom node executable allows Pylance to allocate more memory.
Accepted values:
any executable path or auto
python.analysis.nodeArguments
Extra arguments to pass to node when using python.analysis.nodeExecutable. Defaults to --max-old-space-size=8192
Accepted values:
Any argument that node accepts
python.analysis.autoIndent
Automatically adjust indentation based on language semantics when typing Python code.
Accepted values:
true (default)
false
python.analysis.autoSplitStrings
Automatically add quote and line continuation characters when splitting strings.
Accepted values:
true (default)
false
python.analysis.supportRestructuredText
Enable/disable support for reStructuredText in docstrings.
Default value: false (or true in full mode)
Accepted values:
true (default)
false
Performance Consideration:
Disabling support for reStructuredText in docstrings by setting python.analysis.supportRestructuredText to false can improve performance by reducing the overhead of parsing complex docstrings.
python.analysis.aiCodeActions
Enable/disable AI-assisted code actions. Requires the Copilot Chat extension to be enabled.
This setting accepts objects where the keys are the available AI-assisted code actions, and the values are true or false to enable or disable each action.
Enable/disable support for reStructuredText docstring generation.
Default value: false (or true in full mode)
Accepted values:
true
false (default)
Example:
def foo(arg): """|<Trigger completion or code action here"""
python.analysis.displayEnglishDiagnostics
Display diagnostics in English regardless of VS Code’s display language.
Accepted values:
true
false (default)
python.analysis.generateWithTypeAnnotation
Add type annotations when generating code. Defaults to false for type checking mode off, and true for other modes.
Accepted values:
true
false (default)
python.analysis.diagnosticsSource
Allows specifing a different language server to use for diagnostics. Pylance will merge its results with this other server. The merge algorithm depends upon which server is chosen.
Accepted values:
Pylance (default)
Pyright - Allows running a different version of Pyright to generate diagnostics. Pyright diagnostics will completely replace the diagnostics for Pylance. See the python.analysis.pyrightVersion setting.
python.analysis.pyrightVersion
Specifies the version of Pyright to use for diagnostics. This setting is only used when python.analysis.diagnosticsSource is set to Pyright. Minimum version required is 1.1.397 or higher.
Accepted values:
version string, i.e. 1.1.397
path to a pyright-langserver.js file. For example, the Pyright installed by the PyPI Pyright module. In that case the path would be something like ~/.cache/pyright-python/1.1.397/node_modules/pyright/dist/pyright-langserver.js
python.analysis.enableColorPicker
Enable/disable color picker in the editor for ‘#RRGGBB’ and ‘#RRGGBBAA’ strings.
Accepted values:
true (default)
false
Semantic highlighting
Visual Studio Code uses TextMate grammars as the main tokenization engine. TextMate grammars work on a single file as input and break it up based on lexical rules expressed in regular expressions.
Semantic tokenization allows language servers to provide additional token information based on the language server’s knowledge on how to resolve symbols in the context of a project. Themes can opt-in to use semantic tokens to improve and refine the syntax highlighting from grammars. The editor applies the highlighting from semantic tokens on top of the highlighting from grammars.
Here’s an example of what semantic highlighting can add:
Without semantic highlighting:
With semantic highlighting:
Semantic colors can be customized in settings.json by associating the Pylance semantic token types and modifiers with the desired colors.
Semantic token types
class, enum
parameter, variable, property, enumMember
function, member
module
intrinsic
magicFunction (dunder methods)
selfParameter, clsParameter
Semantic token modifiers
declaration
readonly, static, abstract
async
typeHint, typeHintComment
decorator
builtin
documentation
overridden
callable
The scope inspector tool allows you to explore what semantic tokens are present in a source file and what theme rules they match to.
Example of customizing semantic colors in settings.json:
{ "editor.semanticTokenColorCustomizations": { "[One Dark Pro]": { // Apply to this theme only "enabled": true, "rules": { "magicFunction:python": "#ee0000", "function.declaration:python": "#990000", "*.decorator:python": "#0000dd", "*.typeHint:python": "#5500aa", "*.typeHintComment:python": "#aaaaaa" } } }}
Source Code Actions
source.unusedImports
Remove all unused imports in a file
source.convertImportFormat
Convert import format according to python.analysis.importFormat.
source.fixall.pylance
Apply the commands listed in the python.analysis.fixall setting
Pylance leverages Microsoft’s open-source static type checking tool, Pyright, to provide performant language support for Python.
Code contributions are welcomed via the Pyright repo.
Pylance ships with a collection of type stubs for popular modules to provide fast and accurate auto-completions and type checking. Our type stubs are sourced from typeshed and our work-in-progress stub repository, microsoft/python-type-stubs. Type stubs in microsoft/python-type-stubs will be contributed back to typeshed or added inline to source packages once they are of high enough quality.