The mcp-server-public-transport provides real-time public transport data across Europe, primarily for Switzerland and Belgium. Key features include:
Switzerland:
Search train connections between stations with real-time departure times, duration, platforms, and transfers
Search stations by name or location
Get real-time departure boards for specific stations
Find nearby stations using geographical coordinates
Belgium:
Search train connections between stations using iRail API for real-time routes and schedules
Search stations by name
Get live departure boards for specific stations
Retrieve details about specific train vehicles by ID
The server is MCP-compatible and can be integrated with Claude Desktop for enhanced functionality.
mcp-server-public-transport
An MCP-compatible server providing real-time public transport data across Europe.
About
mcp-server-public-transport is a Model Context Protocol (MCP)-compatible local server that provides access to public transport data across Europe. Currently, it integrates APIs from UK, Switzerland, Norway and Belgium, allowing you to retrieve train connections, live departures, and bus locations.
Related MCP server: Maharashtra Transport MCP Server
Feature Implementation Status
Supported Countries
Country | API Base URL | Status |
United Kingdom | ✅ | |
Switzerland | ✅ | |
Belgium | ✅ | |
Norway | ✅ |
Features by Country
Feature | API Path | Status |
United Kingdom | ||
Live Departures |
| ✅ |
Switzerland | ||
Search Connections |
| ✅ |
Station Lookup |
| ✅ |
Departure Board |
| ✅ |
Nearby Stations |
| ✅ |
Belgium | ||
Live Departures |
| ✅ |
Station Lookup |
| ✅ |
Nearby Stations |
| ✅ |
Norway | ||
Place Search |
| ✅ |
Live Departures |
| ✅ |
Trip Planning |
| ✅ |
Nearest Stops |
| ✅ |
Setup
Environment Variables
Set the following environment variables:
Usage with Claude Desktop
Add to your claude_desktop_config.json`:
Replace /ABSOLUTE/PATH/TO/PARENT/FOLDER/mcp-server-public-transport with the actual path where you've cloned the repository.
Note: You may need to put the full path to the uv executable in the command field. You can get this by running which uv on MacOS/Linux or where uv on Windows.
Development
Setting up Development Environment
Clone the repository
git clone https://github.com/mirodn/mcp-server-public-transport.git cd mcp-server-public-transportInstall dependencies
uv syncSet environment variables
cp .env.example .envRun the server
uv run server.py
Running Tests
The project uses pytest for testing with the following commands available:
Code Quality
Continuous Integration
The project includes a GitHub Actions workflow (.github/workflows/test.yml) that automatically:
Runs tests on Python 3.10, 3.11, and 3.12
Executes linting checks using ruff
Runs on every push and pull request to
mainbranch
The CI pipeline ensures code quality and compatibility across supported Python versions before any changes are merged.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
The package is deployed automatically to PyPI when project.version is updated in pyproject.toml.
Follow semver for versioning.