全国地铁站数据实时更新:Python + 高德地图实战

2024-08-30 02:44

本文主要是介绍全国地铁站数据实时更新:Python + 高德地图实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据抓取呢,非常注重时效性。本篇文章记录于2024年8月,介绍如何使用Python和高德地图来获取中国各大城市的最新地铁站数据。通过python脚本,可以直接获取最新的地铁站信息,确保数据与高德地图的数据源同步更新,数据来源:高德地图 | 地铁图 (amap.com);

另外本专栏主打的就是直接copy直接运行即可,动一下脑子,都是对代码的不尊重,对了下面的库包如果没装的话还是要装一下的,关键的也就一个BeautifulSoup包了;

完整代码#运行环境Python 3.11

import json
import requests
from bs4 import BeautifulSoup# 设置请求头,模拟浏览器行为
headers = {'user-agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36'}# 初始化已获取的地铁站ID集合
got_sid = set()
# 初始化线路字典
lines = {}def output_lines():# 输出线路信息到CSV文件with open('lines.csv', 'a+') as f:# 写入CSV文件的表头print('城市行政区划代码', '城市名', '线路id', '线路名', sep=',', file=f)# 遍历所有线路信息for line_id, line in lines.items():# 写入具体线路信息print(line['cityCode'], line['cityName'], line_id, line['lineName'], sep=',', file=f)def get_message(ID, cityname, name):"""获取指定城市的地铁线路信息"""# 构造地铁线路数据的URLurl = f'http://map.amap.com/service/subway?_1555502190153&srhdata={ID}_drw_{cityname}.json'# 发送HTTP GET请求response = requests.get(url=url, headers=headers)# 解析响应内容为文本html = response.text# 将文本解析为JSON对象result = json.loads(html)# 打开或创建用于存储地铁站数据的CSV文件with open('stations.csv', 'a+') as f:# 遍历每一条地铁线路for i in result['l']:# 遍历该线路下的每个地铁站for j in i['st']:# 获取线路名称line_name = i['ln']# 如果线路有分线,则添加分线标识if i['la']:line_name += f"({i['la']})"# 记录线路信息city_code = IDcity_name = nameline_id = i['ls']lines[line_id] = {'lineId': line_id,'lineName': line_name,'cityCode': city_code,'cityName': city_name,}# 记录地铁站信息station = {'cityCode': city_code,'cityName': city_name,'stationId': j['sid'],'stationName': j['n'],'stationPosition': j['sl'],'stationLines': j['r'],}# 如果该地铁站ID已存在于已获取的集合中,则跳过if station['stationId'] in got_sid:continue# 将地铁站ID添加到已获取的集合中got_sid.add(station['stationId'])# 打印地铁站信息print(*station.values())# 将地铁站信息写入CSV文件print(*station.values(), file=f, sep=',')def get_city():"""获取城市列表,并对每个城市调用get_message函数获取其地铁站信息"""# 构造获取城市列表的URLurl = 'http://map.amap.com/subway/index.html?&1100'# 发送HTTP GET请求response = requests.get(url=url, headers=headers)# 解析响应内容为HTML文本html = response.text# 处理编码问题html = html.encode('ISO-8859-1').decode('utf-8')# 使用BeautifulSoup解析HTMLsoup = BeautifulSoup(html, 'lxml')# 获取城市列表res1 = soup.find_all(class_="city-list fl")[0]res2 = soup.find_all(class_="more-city-list")[0]# 打开或创建用于存储地铁站数据的CSV文件with open('stations.csv', 'a+') as f:# 写入CSV文件的表头print('城市行政区划代码', '城市名', '地铁站ID', '地铁站名', '经度', '纬度', '所属线路',sep=',', file=f)# 遍历第一个城市列表中的城市链接for i in res1.find_all('a'):# 获取城市ID值ID = i['id']# 获取城市拼音名cityname = i['cityname']# 获取城市名name = i.get_text()# 调用get_message函数获取该城市的地铁站信息get_message(ID, cityname, name)# 遍历第二个城市列表中的城市链接for i in res2.find_all('a'):# 获取城市ID值ID = i['id']# 获取城市拼音名cityname = i['cityname']# 获取城市名name = i.get_text()# 调用get_message函数获取该城市的地铁站信息get_message(ID, cityname, name)# 主程序入口
if __name__ == '__main__':# 获取城市列表,并对每个城市调用get_message函数get_city()# 输出所有线路信息output_lines()

运行结束会保存二个文件夹一个line.csv,一个station.csv;

station.csv保存的是地铁站点数据,标签包括城市行政区划代码、城市名、地铁站ID、地铁站名、经度、纬度、所属线路,截止到2024年8月开通并且在运营的站点全国有5695座地铁站;

line.csv保存的是线路数据,标签包括城市行政区划代码、城市名、线路id、线路名,截止到2024年8月开通并且在运营的线路全国有311条地铁线;

获取数据之后就是对数据的可视化,由于我们拿到的数据是高德坐标系GCJ02,但我们通常的数据源可能是WGS84,所以我们需要转一下地理坐标系,这里放一个免费的地图经纬度坐标系批量转换工具:地图坐标系批量转换 - 免费在线工具 (latlongconverter.online);

将csv批量转为WGS84坐标后,导入arcgis,【显示xy数据】,坐标选择地理坐标WGS84,arcgispro也同理;

这里不一样的是arcgis需要把点事件导出为新的点图层,而arcgispro可以直接用当前图层,下一步检索【点集转线】;

这里有一个tips:制作基础数据的时候一个站点被多条线路经过的时候,需要每条线都要有一个该站点数据,且站点顺序一定不能错,不然按线路连接的时候会根据当前站点顺序进行连接。

这里以厦门地铁这个湖滨东路为例,需要在制作基础数据的时候单独做二条数据,一条属于尾号907的线路,一条属于914的线路,并且以镇海路所在的一号线为例,数据顺序一定为镇海路、将军祠、中山公园、文灶......,或者倒序,不然原始数据连接顺序会不按实际运行线路方式连接;

点集转线的结果如下,如果需要最新的地铁数据直接重新运行一下脚本即可;

高德地图的线路如下,当然高德的展示数据为了美观会与实际路线存在差异;

这里也直接放一下原始数据:全国地铁站数据(wgs84)_全国地铁资源-CSDN文库

文章仅用于分享个人学习成果与个人存档之用,分享知识,如有侵权,请联系作者进行删除。所有信息均基于作者的个人理解和经验,不代表任何官方立场或权威解读。

这篇关于全国地铁站数据实时更新:Python + 高德地图实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1119582

相关文章

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

python uv包管理小结

《pythonuv包管理小结》uv是一个高性能的Python包管理工具,它不仅能够高效地处理包管理和依赖解析,还提供了对Python版本管理的支持,本文主要介绍了pythonuv包管理小结,具有一... 目录安装 uv使用 uv 管理 python 版本安装指定版本的 Python查看已安装的 Python