当前位置: 首页 > news >正文

【GIS】本地部署nominatim地理编码服务

参考:https://www.cnblogs.com/nonkicat/p/17222677.html

docker 部署命令

4.5 版本 docker 用不了,需要用 4.0 版本

docker run -it   -e PBF_PATH=/data/你的osm文件.osm.pbf   -e FREEZE=true   -e POSTGRES_MAX_CONNECTIONS=100   -p 6666:8080   --name nominatim   -v /宿主机指向pdf目录:/data   -v /osm-maps/data:/nominatim/data   mediagis/nominatim:4.0

耐心等待建立索引

看到以下输出即成功

2025-02-10 11:17:38.015 UTC [764] LOG:  listening on IPv4 address "0.0.0.0", port 5432
2025-02-10 11:17:38.015 UTC [764] LOG:  listening on IPv6 address "::", port 5432
2025-02-10 11:17:38.027 UTC [764] LOG:  listening on Unix socket "/var/run/postgresql/.s.PGSQL.5432"
2025-02-10 11:17:38.105 UTC [765] LOG:  database system was shut down at 2025-02-10 11:17:37 UTC
2025-02-10 11:17:38.118 UTC [764] LOG:  database system is ready to accept connections

查询

$ keyword="人民大学"
$ curl "http://localhost:6666/search.php?q=${keyword}&polygon_geojson=1&format=jsonv2"

输出

[{"place_id": 116078,"licence": "Data © OpenStreetMap contributors, ODbL 1.0. https://osm.org/copyright","osm_type": "node","osm_id": 7861046852,"boundingbox": ["39.960744","39.970744","116.3107286","116.3207286"],"lat": "39.965744","lon": "116.3157286","display_name": "人民大学, 北三环(四通桥), 中关村街道, 海淀区, 北京市, 100872, 中国","place_rank": 30,"category": "railway","type": "station","importance": 0.11100000000000002,"geojson": {"type": "Point","coordinates": [116.3157286,39.965744]}},...................
]

配套 python 代码查询

import requestsdef get_coordinates(keyword):"""根据关键词查询地点的经纬度。参数:keyword (str): 查询的关键词(如地点名称)。返回:list: 包含地点名称和对应经纬度的字典列表。每个字典包含 "place_name", "latitude", "longitude"。"""url = "http://localhost:6666/search.php"params = {"q": keyword,"polygon_geojson": 1,"format": "jsonv2"}try:# 发送 GET 请求response = requests.get(url, params=params)# 检查响应状态码是否为 200(成功)if response.status_code == 200:data = response.json()results = []# 遍历结果并提取经纬度for item in data:place_name = item.get("display_name", "未知地点")# 尝试从 geojson 提取经纬度try:coordinates = item["geojson"]["coordinates"]if item["geojson"]["type"] == "Point":latitude = coordinates[1]longitude = coordinates[0]elif item["geojson"]["type"] == "Polygon":# 如果是 Polygon,取第一个点作为代表latitude = coordinates[0][0][1]longitude = coordinates[0][0][0]else:# 如果类型未知,跳过该条目print(f"未知的 GeoJSON 类型: {item['geojson']['type']},跳过地点: {place_name}")continueexcept (KeyError, IndexError, TypeError):# 如果 geojson 不可用,尝试使用 lat 和 lon 字段try:latitude = float(item["lat"])longitude = float(item["lon"])except KeyError:print(f"无法提取经纬度信息,跳过地点: {place_name}")continue# 添加到结果列表results.append({"place_name": place_name,"latitude": latitude,"longitude": longitude})return resultselse:print(f"请求失败,状态码: {response.status_code}")return []except requests.exceptions.RequestException as e:print(f"网络请求出错: {e}")return []except ValueError as e:print(f"JSON 解析出错: {e}")return []# 测试样例
keywords = ["北京大学",          # 大学"天安门广场",       # 广场"故宫博物院",       # 博物馆"北京站",           # 火车站"颐和园",           # 公园"中关村创业大街",   # 街道"清华大学",         # 大学"国家体育场",       # 体育场馆(鸟巢)"首都国际机场",     # 机场"人民大会堂"        
]for keyword in keywords:print(f"查询关键词: {keyword}")coordinates = get_coordinates(keyword)if coordinates:for result in coordinates:print(f"地点名称: {result['place_name']}")print(f"纬度: {result['latitude']}, 经度: {result['longitude']}")print("-" * 40)else:print("未找到任何地点信息。")print("\n" + "=" * 80 + "\n")
http://www.lryc.cn/news/535223.html

相关文章:

  • HTML之JavaScript对象声明
  • PyCharm结合DeepSeek-R1
  • innovus如何分步长func和dft时钟
  • 1.1 单元测试核心原则
  • 前端智能识别解析粘贴板内容
  • AI工具发展全景分析与战略展望
  • (定时器,绘制事件,qt简单服务器的搭建)2025.2.11
  • C++17十大常用特性
  • 【机器学习】超参数的选择,以kNN算法为例
  • 【RabbitMQ的监听器容器Simple和Direct】 实现和场景区别
  • NO.13十六届蓝桥杯备战|条件操作符|三目操作符|逻辑操作符|!||||(C++)
  • 2025.1.8(qt图形化界面之消息框)
  • 旅游行业内容管理系统CMS提升网站建设效率与体验
  • 使用 Scrapy 抓取网页数据
  • C# OpenCV机器视觉:SoftNMS非极大值抑制
  • kamailio关于via那点事
  • [MFC] 使用控件
  • 【探索未来科技】2025年国际学术会议前瞻
  • 使用wpa_supplicant和wpa_cli 扫描wifi热点及配网
  • Sealos的k8s高可用集群搭建
  • Android和DLT日志系统
  • 【openresty服务器】:源码编译openresty支持ssl,增加service系统服务,开机启动,自己本地签名证书,配置https访问
  • 如何将网站提交百度收录完整SEO教程
  • 【STM32】ADC|多通道ADC采集
  • 蓝桥杯算法日记|贪心、双指针
  • ArcGIS Pro SDK (二十七)自定义许可
  • 通过客户端Chatbox或OpenwebUI访问识别不到本地ollama中的模型等问题的解决
  • 速度超越DeepSeek!Le Chat 1100tok/s闪电回答,ChatGPT 4o和DeepSeek R1被秒杀?
  • JVM速成=。=
  • Packer 手动修复安装腾讯云插件