by jjsantos01
Enables Claude AI to control QGIS through a socket‑based server, allowing direct project creation, layer manipulation, processing execution, and arbitrary Python code execution within the desktop GIS environment.
QGIS MCP provides a two‑way communication channel between Claude AI and QGIS, exposing a set of tools that let the LLM create, edit, and render GIS projects programmatically.
qgis_mcp_plugin
folder into QGIS’s user‐profile python/plugins
directory.claude_desktop_config.json
(see configuration below).Q: Which versions of QGIS are supported? A: Tested on QGIS 3.22; other 3.X versions should work but are not officially verified.
Q: Do I need an internet connection? A: Only for downloading dependencies (uv, Python packages). The socket communication runs locally.
Q: Is executing arbitrary code safe? A: It gives full access to the QGIS Python environment, so only enable this when you trust the LLM’s output or run in a sandbox.
Q: How do I stop the server? A: Use the plugin’s UI in QGIS to stop the socket server, or close QGIS entirely.
Q: Can I use a different LLM than Claude? A: Any client that implements the Model Context Protocol can connect, provided it points to the same MCP server configuration.
QGISMCP connects QGIS to Claude AI through the Model Context Protocol (MCP), allowing Claude to directly interact with and control QGIS. This integration enables prompt assisted project creation, layer loading, code execution and more.
This project is strongly based on the BlenderMCP project by Siddharth Ahuja
The system consists of two main components:
If you're on Mac, please install uv as
brew install uv
On Windows Powershell
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
Otherwise installation instructions are on their website: Install uv
⚠️ Do not proceed before installing UV
Download this repo to your computer. You can clone it with:
git clone git@github.com:jjsantos01/qgis_mcp.git
You need to copy the folder qgis_mcp_plugin and its content on your QGIS profile plugins folder.
You can get your profile folder in QGIS going to menu Settings
-> User profiles
-> Open active profile folder
Then, go to Python/plugins
and paste the folder qgis_mcp_plugin
.
On a Windows machine the plugins folder is usually located at:
C:\Users\USER\AppData\Roaming\QGIS\QGIS3\profiles\default\python\plugins
and on MacOS:~/Library/Application\ Support/QGIS/QGIS3/profiles/default/python/plugins
Then close QGIS and open it again. Go to the menu option Plugins
-> Installing and Managing Plugins
, select the All
tab and search for "QGIS MCP", then mark the QGIS MCP checkbox.
Go to Claude
> Settings
> Developer
> Edit Config
> claude_desktop_config.json
to include the following:
If you cann't find the "Developers tab" or the
claude_desktop_config.json
look at this documentation.
{
"mcpServers": {
"qgis": {
"command": "uv",
"args": [
"--directory",
"/ABSOLUTE/PATH/TO/PARENT/REPO/FOLDER/qgis_mcp/src/qgis_mcp",
"run",
"qgis_mcp_server.py"
]
}
}
}
plugins
-> QGIS MCP
-> QGIS MCP
Once the config file has been set on Claude, and the server is running on QGIS, you will see a hammer icon with tools for the QGIS MCP.
ping
- Simple ping command to check server connectivityget_qgis_info
- Get QGIS information about the current installationload_project
- Load a QGIS project from the specified pathcreate_new_project
- Create a new project and save itget_project_info
- Get current project informationadd_vector_layer
- Add a vector layer to the projectadd_raster_layer
- Add a raster layer to the projectget_layers
- Retrieve all layers in the current projectremove_layer
- Remove a layer from the project by its IDzoom_to_layer
- Zoom to the extent of a specified layerget_layer_features
- Retrieve features from a vector layer with an optional limitexecute_processing
- Execute a processing algorithm with the given parameterssave_project
- Save the current project to the given pathrender_map
- Render the current map view to an image fileexecute_code
- Execute arbitrary PyQGIS code provided as a stringThis is the example I used for the demo:
You have access to the tools to work with QGIS. You will do the following:
1. Ping to check the connection. If it works, continue with the following steps.
2. Create a new project and save it at: "C:/Users/USER/GitHub/qgis_mcp/data/cdmx.qgz"
3. Load the vector layer: ""C:/Users/USER/GitHub/qgis_mcp/data/cdmx/mgpc_2019.shp" and name it "Colonias".
4. Load the raster layer: "C:/Users/USER/GitHub/qgis_mcp/data/09014.tif" and name it "BJ"
5. Zoom to the "BJ" layer.
6. Execute the centroid algorithm on the "Colonias" layer. Skip the geometry check. Save the output to "colonias_centroids.geojson".
7. Execute code to create a choropleth map using the "POB2010" field in the "Colonias" layer. Use the quantile classification method with 5 classes and the Spectral color ramp.
8. Render the map to "C:/Users/USER/GitHub/qgis_mcp/data/cdmx.png"
9. Save the project.
Please log in to share your review and rating for this MCP.
{ "mcpServers": { "qgis": { "command": "uv", "args": [ "--directory", "/ABSOLUTE/PATH/TO/PARENT/REPO/FOLDER/qgis_mcp/src/qgis_mcp", "run", "qgis_mcp_server.py" ] } } }
Explore related MCPs that share similar capabilities and solve comparable challenges
by zed-industries
A high‑performance, multiplayer code editor designed for speed and collaboration.
by modelcontextprotocol
Model Context Protocol Servers
by modelcontextprotocol
A Model Context Protocol server for Git repository interaction and automation.
by modelcontextprotocol
A Model Context Protocol server that provides time and timezone conversion capabilities.
by cline
An autonomous coding assistant that can create and edit files, execute terminal commands, and interact with a browser directly from your IDE, operating step‑by‑step with explicit user permission.
by continuedev
Enables faster shipping of code by integrating continuous AI agents across IDEs, terminals, and CI pipelines, offering chat, edit, autocomplete, and customizable agent workflows.
by upstash
Provides up-to-date, version‑specific library documentation and code examples directly inside LLM prompts, eliminating outdated information and hallucinated APIs.
by github
Connects AI tools directly to GitHub, enabling natural‑language interactions for repository browsing, issue and pull‑request management, CI/CD monitoring, code‑security analysis, and team collaboration.
by daytonaio
Provides a secure, elastic infrastructure that creates isolated sandboxes for running AI‑generated code with sub‑90 ms startup, unlimited persistence, and OCI/Docker compatibility.