MCP server for Swiss labor market data (SECO/AMSTAT) – Arbeitsmarkt & Stellensuche
Project description
seco-labor-mcp
Swiss Public Data MCP Portfolio · malkreide
An MCP (Model Context Protocol) server for Swiss labor market data from SECO (Staatssekretariat für Wirtschaft) and AMSTAT via opendata.swiss.
Overview
This server connects AI models to Swiss labor market statistics — unemployment rates, job seekers, open positions, youth unemployment, and occupational breakdowns — all without requiring an API key.
Primary audiences:
- 🏫 Schulamt / Education planning — youth unemployment, vocational guidance data
- 📊 Research & analysis — labor market trends, cantonal comparisons
- 🤖 AI agents — automated labor market monitoring and reporting
Anchor query:
"Welche Berufsgruppen haben im Kanton Zürich die höchste Jugendarbeitslosigkeit, und welche Lehrberufe unterliegen der Stellenmeldepflicht?"
Data Sources (Phase 1 — No Auth Required)
| Source | Description | Status |
|---|---|---|
| opendata.swiss | CKAN metadata catalog with SECO dataset CSVs | ✅ Live |
| arbeit.swiss | Monthly press reports (PDF, structured URL pattern) | ✅ Live |
| amstat.ch | AMSTAT reference portal | ⚠️ JavaScript SPA, no public REST API |
Architecture
┌─────────────────────────────────────────────────────┐
│ seco-labor-mcp │
│ │
│ ┌─────────────┐ ┌──────────────────────────┐ │
│ │ FastMCP │ │ 9 MCP Tools │ │
│ │ Server │◄──►│ seco_search_datasets │ │
│ │ (stdio / │ │ seco_get_dataset │ │
│ │ SSE) │ │ seco_get_unemployment_* │ │
│ └─────────────┘ │ seco_get_youth_* │ │
│ │ │ seco_get_job_seekers │ │
│ ▼ │ seco_get_open_positions │ │
│ ┌─────────────┐ │ seco_get_monthly_url │ │
│ │ httpx │ │ seco_list_cantons │ │
│ │ async │ └──────────────────────────┘ │
│ └──────┬──────┘ │
└─────────┼───────────────────────────────────────────┘
│
▼
┌───────────────────────────────────┐
│ opendata.swiss CKAN API │
│ https://opendata.swiss/api/3/ │
│ action/package_search │
│ action/package_show │
└───────────┬───────────────────────┘
│
▼
┌───────────────────────────────────┐
│ SECO Data Resources │
│ CSV / XLSX / PDF Downloads │
│ (monthly labor market data) │
└───────────────────────────────────┘
Tools
| Tool | Description | Key Use Case |
|---|---|---|
seco_search_datasets |
Search SECO datasets on opendata.swiss | Discovery |
seco_get_dataset |
Full metadata + download links for a dataset | Data access |
seco_get_unemployment_overview |
National/cantonal unemployment figures | Labor market overview |
seco_get_youth_unemployment |
Youth unemployment (15–24 year olds) | 🎓 Berufswahlberatung |
seco_get_job_seekers |
Stellensuchende (broader than unemployed) | Training demand |
seco_get_open_positions |
Open positions — leading indicator | Sector analysis |
seco_get_unemployment_by_occupation |
Breakdown by Berufshauptgruppe | 🎓 Vocational guidance |
seco_get_monthly_report_url |
Generate/verify PDF report URL | Source access |
seco_list_cantons |
All 26 canton codes and names | Utility |
Installation
Claude Desktop (stdio)
Add to claude_desktop_config.json:
{
"mcpServers": {
"seco-labor": {
"command": "uvx",
"args": ["seco-labor-mcp"]
}
}
}
Cloud / SSE
pip install seco-labor-mcp
MCP_TRANSPORT=sse PORT=8000 seco-labor-mcp
Development
git clone https://github.com/malkreide/seco-labor-mcp.git
cd seco-labor-mcp
pip install -e ".[dev]"
pytest tests/ -m "not live" -v
Usage Examples
Search for youth unemployment data
Tool: seco_search_datasets
Input: { "query": "Jugendarbeitslosigkeit Alter", "limit": 5 }
Get cantonal unemployment for Zürich
Tool: seco_get_unemployment_overview
Input: { "canton": "ZH", "response_format": "markdown" }
Get monthly report URL
Tool: seco_get_monthly_report_url
Input: { "year": 2026, "month": 2, "language": "de" }
Key Concepts
Arbeitslose vs. Stellensuchende
Eselsbrücke: Arbeitslose ⊂ Stellensuchende — Arbeitslose sind eine Teilmenge.
| Term | Definition | Dec 2025 |
|---|---|---|
| Arbeitslose | RAV-registered, immediately available | ~149'000 (3.2%) |
| Stellensuchende | All RAV-registered (incl. training programs) | ~233'900 |
Youth Unemployment Seasonality
- July/August: Sharp increase (school leavers without placements)
- September/October: Decline (apprenticeship starts)
- The residual that remains after the autumn decline signals structural need for bridge programs (Brückenangebote)
Stellenmeldepflicht (since 2020)
Occupations with ≥5% unemployment rate must be reported to the RAV before posting publicly. The list changes annually. This is directly relevant for vocational counseling — these professions have highest availability for Swiss job seekers.
Portfolio Synergies
| Server | Synergy |
|---|---|
swiss-statistics-mcp |
BFS population/employment data for deeper context |
zurich-opendata-mcp |
City of Zurich-level education and social data |
swiss-snb-mcp |
Economic context (GDP, wages) for labor market interpretation |
fedlex-mcp |
ALV (Arbeitslosenversicherung) legislative framework |
Known Limitations
amstat.arbeit.swisshas no public REST API (JavaScript SPA) → workaround via CKAN- Occupational/sectoral detail requires CSV download from SECO resources
- Monthly press report URL patterns may vary for older reports
- Cantonal sub-municipal data not available at this level
Phase 2 roadmap:
- Automatic CSV caching with 24h TTL
- Direct XLSX parsing for cantonal breakdowns
- Integration with
zh-education-mcpfor Schulamt-specific correlations
Data License
SECO data published on opendata.swiss is under Creative Commons CCZero (public domain).
Source: Staatssekretariat für Wirtschaft (SECO) — seco.admin.ch
Contributing
See CONTRIBUTING.md for development guidelines.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file seco_labor_mcp-0.1.0.tar.gz.
File metadata
- Download URL: seco_labor_mcp-0.1.0.tar.gz
- Upload date:
- Size: 23.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
81993d52d293003920d312d0749fb69f692d72550772e9eb37014063e58fd4bf
|
|
| MD5 |
cbe77ed60e34211343849be025ff9ecc
|
|
| BLAKE2b-256 |
e9356f41058cc6a2264be04413435a560e835e8d59d72cefcea7a95759cc4eff
|
Provenance
The following attestation bundles were made for seco_labor_mcp-0.1.0.tar.gz:
Publisher:
publish.yml on malkreide/seco-labor-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
seco_labor_mcp-0.1.0.tar.gz -
Subject digest:
81993d52d293003920d312d0749fb69f692d72550772e9eb37014063e58fd4bf - Sigstore transparency entry: 1206120006
- Sigstore integration time:
-
Permalink:
malkreide/seco-labor-mcp@89fc337e453b4b98c2b1584662aa8bfd108e0124 -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/malkreide
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@89fc337e453b4b98c2b1584662aa8bfd108e0124 -
Trigger Event:
release
-
Statement type:
File details
Details for the file seco_labor_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: seco_labor_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1edf9af7914fd13627e66babe3a75c436b89b13d29543059185b1b83204c564f
|
|
| MD5 |
6680009a9465e9ed8d7c818629647f92
|
|
| BLAKE2b-256 |
9629c29c5ca4d2315616498315509b51ae883681a4b6fba9d752e165647962db
|
Provenance
The following attestation bundles were made for seco_labor_mcp-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on malkreide/seco-labor-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
seco_labor_mcp-0.1.0-py3-none-any.whl -
Subject digest:
1edf9af7914fd13627e66babe3a75c436b89b13d29543059185b1b83204c564f - Sigstore transparency entry: 1206120007
- Sigstore integration time:
-
Permalink:
malkreide/seco-labor-mcp@89fc337e453b4b98c2b1584662aa8bfd108e0124 -
Branch / Tag:
refs/tags/0.2.0 - Owner: https://github.com/malkreide
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@89fc337e453b4b98c2b1584662aa8bfd108e0124 -
Trigger Event:
release
-
Statement type: