Pylance is a fast, feature-rich language support extension for Python in Visual Studio Code, powered by the Pyright static type checker. It provides advanced type checking, auto-completions, code navigation, and other language features to enhance your Python development experience.
To provide features like auto-import suggestions and workspace symbol searches, Pylance indexes your project's Python files. In large workspaces, this indexing process can consume significant resources and impact performance.
The python.analysis.userFileIndexingLimit
setting allows you to control the number of user files Pylance indexes, helping you balance functionality and performance in your development environment.
User file indexing is the process where Pylance scans and indexes Python files in your workspace (user files). This indexing enables several powerful features:
- Auto-Import Suggestions: Pylance can suggest imports from your codebase when you reference symbols not yet imported.
- Workspace Symbol Search: Quickly navigate to symbols (classes, functions, variables) defined anywhere in your workspace.
- Enhanced Misc Features: Used for other miscellaneous features such as code generation, document outline, and document symbols.
While indexing enhances productivity, it can be resource-intensive in large projects with thousands of files, potentially affecting performance.
The python.analysis.userFileIndexingLimit
setting controls the maximum number of user (workspace) files that Pylance will index. By adjusting this limit, you can manage Pylance's resource consumption and improve performance in large workspaces.
-
Default Value:
2000
By default, Pylance indexes up to 2,000 Python files in your workspace.
-
Custom Value: You can set this to any positive integer or
-1
:- Positive Integer: Pylance will index up to that number of files.
-1
: Pylance will index all Python files in your workspace, regardless of the number.
In projects with a large number of Python files, indexing all files can lead to high memory usage and CPU load, potentially slowing down your development environment or causing Pylance to crash with out-of-memory errors.
By setting python.analysis.userFileIndexingLimit
to a lower number, you can reduce the resource impact of indexing, at the cost of reduced functionality in features that rely on indexing.
You can adjust the python.analysis.userFileIndexingLimit
setting in Visual Studio Code to control Pylance's indexing behavior.
-
Open Settings:
- Click on the gear icon in the lower-left corner and select Settings.
-
Find the Setting:
- In the search bar at the top, type
python.analysis.userFileIndexingLimit
.
- In the search bar at the top, type
-
Modify the Setting:
- Enter the desired integer value in the input box. For example, enter
1000
to limit indexing to 1,000 files.
- Enter the desired integer value in the input box. For example, enter
-
Open Command Palette:
- Click on the gear icon in the lower-left corner and select Command Palette.
-
Open Settings (JSON):
- Type
Preferences: Open Settings (JSON)
and select it.
- Type
-
Add or Modify the Setting:
-
Add the following line to your
settings.json
file:"python.analysis.userFileIndexingLimit": 1000
-
Replace
1000
with the desired limit, or-1
to index all files.
-
A: Indexing affects features like auto-import suggestions, workspace symbol search, and some code navigation capabilities. Reducing the indexing limit may limit these features to the files that are indexed.
A: Yes, consider adjusting:
-
python.analysis.indexing
: Set tofalse
to disable indexing entirely."python.analysis.indexing": false
This will disable both user file indexing and library indexing.
-
python.analysis.include
andpython.analysis.exclude
: Specify which files or directories Pylance should include or exclude from analysis."python.analysis.exclude": [ "**/node_modules", "**/__pycache__", "*.gen.py" ]
A: It depends on your project's size and your machine's capabilities. Start with the default value and adjust as needed. Monitor Pylance's performance and resource usage to find an optimal setting.
A: Yes, reducing the indexing limit may limit auto-import suggestions and symbol searches to the indexed files. IntelliSense within open files will still function, but some features that rely on indexing may be restricted.
Q: What is the difference between packageIndexDepths
and userFileIndexingLimit
?
A: The packageIndexDepths
setting controls the indexing of third-party library packages (e.g., files under site-packages
), allowing you to specify how deeply Pylance should index these libraries. In contrast, the userFileIndexingLimit
setting controls the indexing of user Python files (e.g., files within your workspace). Together, these settings enable you to customize the scope and depth of indexing for both user and third-party code.
For more information on Pylance settings and customization, refer to the Pylance Settings and Customization documentation.
This document was generated with the assistance of AI and has been reviewed by humans for accuracy and completeness.