QGIS MCP Server

1

Add it to Claude Code

Run this in a terminal.

Run in terminal
claude mcp add qgis-mcp -- uv run src/qgis_mcp/server.py
README.md

Connect QGIS to Claude AI to manage layers, edit features, and render maps.

QGIS MCP

Connect QGIS to Claude AI through the Model Context Protocol (MCP), enabling Claude to directly control QGIS — manage layers, edit features, run processing algorithms, render maps, and more.

51 MCP tools covering layer management, feature editing, processing, rendering, styling, plugin development, and system management. Compatible with QGIS 3.28–4.x. Includes a one-command installer for 6+ MCP clients.

Architecture

Claude ←→ MCP Server (FastMCP) ←→ TCP socket ←→ QGIS Plugin (QTimer) ←→ PyQGIS API
  1. QGIS Plugin (qgis_mcp_plugin/) — Runs inside QGIS. Non-blocking TCP socket server that processes JSON commands within QGIS's event loop.
  2. MCP Server (src/qgis_mcp/server.py) — Runs outside QGIS. Exposes QGIS operations as MCP tools via FastMCP.

Prerequisites

  • QGIS 3.28 or newer
  • Python 3.12+
  • uv package manager — install uv

Installation

1. Clone the repository

git clone https://github.com/nkarasiak/qgis-mcp.git
cd qgis-mcp

2. Install with the one-command installer (recommended)

python install.py

This will:

  • Symlink the QGIS plugin into your QGIS profile
  • Configure your MCP client(s) — supports Claude Desktop, Claude Code, Cursor, VS Code Copilot, Windsurf, and Zed

Options: --non-interactive --clients claude-desktop,cursor for CI, --remote for uvx-based installs, --profile myprofile for non-default QGIS profiles, --uninstall to remove.

Restart QGIS, then enable the plugin: Plugins > Manage and Install Plugins > search "QGIS MCP" > check the box.

Manual installation
Install the QGIS plugin manually

Copy (or symlink) the qgis_mcp_plugin/ folder into your QGIS plugins directory:

Find your plugins folder: In QGIS, go to Settings > User Profiles > Open Active Profile Folder, then navigate to python/plugins/.

OS Typical path
Linux ~/.local/share/QGIS/QGIS3/profiles/default/python/plugins/
macOS ~/Library/Application Support/QGIS/QGIS3/profiles/default/python/plugins/
Windows %APPDATA%\QGIS\QGIS3\profiles\default\python\plugins\
# Example on Linux (symlink recommended for development)
ln -s /path/to/qgis-mcp/qgis_mcp_plugin ~/.local/share/QGIS/QGIS3/profiles/default/python/plugins/qgis_mcp_plugin

Restart QGIS, then enable the plugin: Plugins > Manage and Install Plugins > search "QGIS MCP" > check the box.

Connect your MCP client manually
Claude Code — project-level config (recommended)

Create a .mcp.json file at the root of your clone:

{
  "mcpServers": {
    "qgis": {
      "command": "uv",
      "args": ["run", "src/qgis_mcp/server.py"],
      "cwd": "/path/to/qgis-mcp"
    }
  }
}

Claude Code automatically detects .mcp.json when you open the project — no manual claude mcp add needed.

Claude Code — one-liner (remote install)
claude mcp add --transport stdio qgis-mcp -- uvx --from git+https://github.com/nkarasiak/qgis-mcp qgis-mcp-server
Claude Desktop

Go to Claude > Settings > Developer > Edit Config and add:

{
  "mcpServers": {
    "qgis": {
      "command": "uv",
      "args": ["run", "src/qgis_mcp/server.py"],
      "cwd": "/path/to/qgis-mcp"
    }
  }
}

Or for a remote install without cloning:

{
  "mcpServers": {
    "qgis": {
      "command": "uvx",
      "args": [
        "--from", "git+https://github.com/nkarasiak/qgis-mcp",
        "qgis-mcp-server"
      ]
    }
  }
}
Cursor / other MCP clients

Use the same JSON configuration above in your client's MCP settings file.

Usage

  1. Start the plugin — In QGIS, click the MCP toolbar button (or Plugins > QGIS MCP) and click "Start Server"
  2. Talk to Claude — The MCP tools will appear automatically. Ask Claude to work with your QGIS project.

Example prompt

You have access to QGIS tools. Do the following:
1. Ping to check the connection
2. Create a new project and save it at "/tmp/my_project.qgz"
3. Load the vector layer "/data/cities.shp" and name it "Cities"
4. Get field statistics for the "population" field
5. Create a graduated symbology on the "population" field with 5 classes
6. Render the map and show me the result
7. Save the project

Tools (51)

Category Tools
Project load_project, create_new_project, save_project, get_project_info
Layers get_layers, add_vector_layer, add_raster_layer, remove_layer, find_layer, create_memory_layer, set_layer_visibility, zoom_to_layer, get_layer_extent, set_layer_property
Features get_layer_features, add_features, update_features, delete_features, select_features, get_selection, `cl

Tools (6)

load_projectLoads a QGIS project file.
create_new_projectCreates a new QGIS project.
save_projectSaves the current QGIS project.
get_project_infoRetrieves information about the current project.
add_vector_layerAdds a vector layer to the project.
add_raster_layerAdds a raster layer to the project.

Configuration

claude_desktop_config.json
{"mcpServers": {"qgis": {"command": "uv", "args": ["run", "src/qgis_mcp/server.py"], "cwd": "/path/to/qgis-mcp"}}}

Try it

Create a new project and save it at '/tmp/my_project.qgz'
Load the vector layer '/data/cities.shp' and name it 'Cities'
Get field statistics for the 'population' field
Create a graduated symbology on the 'population' field with 5 classes
Render the map and show me the result

Frequently Asked Questions

What are the key features of QGIS MCP?

Direct control of QGIS via natural language. Supports layer management, feature editing, and map rendering. Executes QGIS processing algorithms. Compatible with QGIS 3.28–4.x. Includes a one-command installer for multiple MCP clients.

What can I use QGIS MCP for?

Automating repetitive GIS data processing tasks. Generating map visualizations through natural language prompts. Managing complex QGIS project layers and properties via AI. Performing feature editing and statistical analysis on spatial data.

How do I install QGIS MCP?

Install QGIS MCP by running: python install.py

What MCP clients work with QGIS MCP?

QGIS MCP works with any MCP-compatible client including Claude Desktop, Claude Code, Cursor, and other editors with MCP support.

Turn this server into reusable context

Keep QGIS MCP docs, env vars, and workflow notes in Conare so your agent carries them across sessions.

Need the old visual installer? Open Conare IDE.
Open Conare