Provides tools to query and retrieve geographic data for cities and regions, utilizing Wikidata identifiers and relations to provide details like location coordinates, population, and elevation.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Geodb Cities MCP Serverfind cities within 100km of Paris with a population over 500,000"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Geodb Cities MCP Server
用于访问 Geodb Cities API 的 MCP 服务器。
🚀 使用 EMCP 平台快速体验
EMCP 是一个强大的 MCP 服务器管理平台,让您无需手动配置即可快速使用各种 MCP 服务器!
快速开始:
🌐 访问 EMCP 平台
📝 注册并登录账号
🎯 进入 MCP 广场,浏览所有可用的 MCP 服务器
🔍 搜索或找到本服务器(
bach-geodb_cities)🎉 点击 "安装 MCP" 按钮
✅ 完成!即可在您的应用中使用
EMCP 平台优势:
✨ 零配置:无需手动编辑配置文件
🎨 可视化管理:图形界面轻松管理所有 MCP 服务器
🔐 安全可靠:统一管理 API 密钥和认证信息
🚀 一键安装:MCP 广场提供丰富的服务器选择
📊 使用统计:实时查看服务调用情况
立即访问 EMCP 平台 开始您的 MCP 之旅!
简介
这是一个 MCP 服务器,用于访问 Geodb Cities API。
PyPI 包名:
bach-geodb_cities版本: 1.0.0
传输协议: stdio
安装
从 PyPI 安装:
从源码安装:
运行
方式 1: 使用 uvx(推荐,无需安装)
方式 2: 直接运行(开发模式)
方式 3: 安装后作为命令运行
配置
API 认证
此 API 需要认证。请设置环境变量:
环境变量
变量名 | 说明 | 必需 |
| API 密钥 | 是 |
| 不适用 | 否 |
| 不适用 | 否 |
在 Cursor 中使用
编辑 Cursor MCP 配置文件 ~/.cursor/mcp.json:
在 Claude Desktop 中使用
编辑 Claude Desktop 配置文件 claude_desktop_config.json:
可用工具
此服务器提供以下工具:
place_distance
Gets this place's distance to the given place.
端点: GET /v1/geo/places/{placeId}/distance
参数:
distanceUnit(string): The unit of distance: KM | MI [default]toPlaceId(string): The distance to this placeplaceId(string) 必需: Example value:
place_time
Get this place's current time in ISO-8601 format: HHmmss.SSSZ
端点: GET /v1/geo/places/{placeId}/time
参数:
placeId(string) 必需: Example value:
place_date_time
Get this place's current date-time in ISO-6801 format: yyyyMMdd'T'HHmmssZ
端点: GET /v1/geo/places/{placeId}/dateTime
参数:
placeId(string) 必需: Example value:
place_located_in
Get the details for the containing populated place (e.g., its county or other administrative division), including location coordinates, population, and elevation above sea-level (if available). Currently, this data is highly dependent on whether the Wikidata locatedIn relation is properly defined. If you see an issue, please propose a change to the corresponding Wikidata entry.
端点: GET /v1/geo/places/{placeId}/locatedIn
参数:
placeId(string) 必需: Example value:
place_details
Get the details for a specific place, including location coordinates, population, and elevation above sea-level (if available).
端点: GET /v1/geo/places/{placeId}
参数:
languageCode(string): Display results in this languageasciiMode(string): Example value:placeId(string) 必需: Example value:
city_located_in
Get the details for the containing populated place (e.g., its county or other administrative division), including location coordinates, population, and elevation above sea-level (if available). Currently, this data is highly dependent on whether the Wikidata locatedIn relation is properly defined. If you see an issue, please propose a change to the corresponding Wikidata entry.
端点: GET /v1/geo/cities/{cityId}/locatedIn
参数:
cityId(string) 必需: Example value: Q65
places_near_location
Get places near the given location, filtering by optional criteria.
端点: GET /v1/geo/locations/{locationid}/nearbyPlaces
参数:
types(string): Only places for these types (comma-delimited): ADM2 | CITY | ISLANDradius(string) 必需: The location radius within which to find placesdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only places in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only places NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only places in these time-zonesminPopulation(number): Only places having at least this populationmaxPopulation(number): Only places having no more than this populationnamePrefix(string): Only places whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any places marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | populationlocationid(string) 必需: Only cities near this location. Latitude/longitude in ISO-6709 format: ±DD.DDDD±DDD.DDDD
places_near_place
Get places near the given place, filtering by optional criteria.
端点: GET /v1/geo/places/{placeId}/nearbyPlaces
参数:
types(string): Only places for these types (comma-delimited): ADM2 | CITY | ISLANDradius(number) 必需: The location radius within which to find placesdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only places in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only places NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only places in these time-zonesminPopulation(number): Only places having at least this populationmaxPopulation(number): Only places having no more than this populationnamePrefix(string): Only places whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any places marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONEoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | populationplaceId(string) 必需: Example value:
country_places
Get the places in the given country.
端点: GET /v1/geo/countries/{countryId}/places
参数:
types(string): Only cities for these types (comma-delimited): ADM2 | CITY | ISLANDtimeZoneIds(string): Only places in these time-zonesminPopulation(number): Only places having at least this populationmaxPopulation(number): Only places having no more than this populationnamePrefix(string): Only places whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any cities marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = elevation | name | populationcountryId(string) 必需: Example value: US
country_region_divisions
Get the administrative divisions in the given region.
端点: GET /v1/geo/countries/{countryid}/regions/{regioncode}/adminDivisions
参数:
minPopulation(number): Only cities having at least this populationmaxPopulation(number): Only divisions having no more than this populationnamePrefix(string): Only divisions whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any cities marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = elevation | name | populationcountryid(string) 必需: An ISO-3166 country code or WikiData idregioncode(string) 必需: An ISO-3166 or FIPS region code
admin_division_details
Get the details for a specific administrative division, including location coordinates, population, and elevation above sea-level (if available).
端点: GET /v1/geo/adminDivisions/{divisionId}
参数:
languageCode(string): Display results in this languageasciiMode(string): Example value:divisionId(string) 必需: Example value: Q104994
cities_near_division
Get cities near the given administrative division, filtering by optional criteria.
端点: GET /v1/geo/adminDivisions/{divisionId}/nearbyCities
参数:
types(string): Only cities for these types (comma-delimited): CITY | ADM2radius(number) 必需: The location radius within which to find citiesdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only cities in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only cities NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only cities in these time-zonesminPopulation(number): Only cities having at least this populationmaxPopulation(number): Only cities having no more than this populationnamePrefix(string): Only cities whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any cities marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | populationdivisionId(string) 必需: Example value: Q104994
admin_divisions
Find administrative divisions, filtering by optional criteria. If no criteria are set, you will get back all known divisions with a population of at least 1000
端点: GET /v1/geo/adminDivisions
参数:
location(string): Only divisions near this location. Latitude/longitude in ISO-6709 format: ±DD.DDDD±DDD.DDDDradius(number): The location radius within which to find divisionsdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only divisions in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only divisions NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only divisions in these time-zonesminPopulation(number): Only divisions having at least this populationmaxPopulation(number): Only divisions having no more than this populationnamePrefix(string): Only divisions whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any divisions marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | population
country_region_places
Get the places in the given region.
端点: GET /v1/geo/countries/{countryid}/regions/{regionId}/places
参数:
types(string): Only cities for these types (comma-delimited): ADM2 | CITY | ISLANDtimeZoneIds(string): Only places in these time-zonesminPopulation(number): Only places having at least this populationmaxPopulation(number): Only places having no more than this populationnamePrefix(string): Only places whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any cities marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = elevation | name | populationcountryid(string) 必需: An ISO-3166 country code or WikiData idregionId(string) 必需: Example value: CA
places
Find places, filtering by optional criteria. If no criteria are set, you will get back all known places.
端点: GET /v1/geo/places
参数:
types(string): Only places for these types (comma-delimited): ADM2 | CITY | ISLANDlocation(string): Only places near this location. Latitude/longitude in ISO-6709 format: ±DD.DDDD±DDD.DDDDradius(number): The location radius within which to find placesdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only places in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only places NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only places in these time-zonesminPopulation(number): Only places having at least this populationmaxPopulation(number): Only places having no more than this populationnamePrefix(string): Only places whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:includeDeleted(string): Whether to include any places marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElanguageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:limit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | population
time_zone
Get the time-zone current time in ISO-6801 format: HHmmss.SSSZ
端点: GET /v1/locale/timezones/{zoneid}
参数:
zoneid(string) 必需: The time-zone id
admin_divisions_near_location
Get administrative divisions near the given location, filtering by optional criteria.
端点: GET /v1/geo/locations/{locationid}/nearbyDivisions
参数:
radius(string) 必需: The location radius within which to find divisionsdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only divisions in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only divisions NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only divisions in these time-zonesminPopulation(number): Only divisions having at least this populationmaxPopulation(number): Only divisions having no more than this populationnamePrefix(string): Only divisions whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any divisions marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | populationlocationid(string) 必需: Only divisions near this location. Latitude/longitude in ISO-6709 format: ±DD.DDDD±DDD.DDDD
admin_divisions_near_division
Get divisions near the given administrative division, filtering by optional criteria.
端点: GET /v1/geo/adminDivisions/{divisionId}/nearbyDivisions
参数:
radius(number) 必需: The location radius within which to find divisionsdistanceUnit(string): The unit of distance to use: MI | KMcountryIds(string): Only divisions in these countries (comma-delimited country codes or WikiData ids)excludedCountryIds(string): Only divisions NOT in these countries (comma-delimited country codes or WikiData ids)timeZoneIds(string): Only divisions in these time-zonesminPopulation(number): Only divisions having at least this populationmaxPopulation(number): Only divisions having no more than this populationnamePrefix(string): Only divisions whose names start with this prefix. If languageCode is set, the prefix will be matched on the name as it appears in that language.namePrefixDefaultLangResults(string): Example value:languageCode(string): Display results in this languageasciiMode(string): Example value:hateoasMode(string): Example value:includeDeleted(string): Whether to include any divisions marked deleted: ALL | SINCE_YESTERDAY | SINCE_LAST_WEEK | NONElimit(number): The maximum number of results to retrieveoffset(number): The zero-ary offset into the resultssort(string): How to sort the results. Format: ±SORT_FIELD,±SORT_FIELD where SORT_FIELD = countryCode | elevation | name | populationdivisionId(string) 必需: Example value: Q104994
技术栈
传输协议: stdio
HTTP 客户端: httpx
许可证
MIT License - 详见 LICENSE 文件。
开发
此服务器由 API-to-MCP 工具生成。
版本: 1.0.0