python画经纬度数据库 python经纬度画动态轨迹图 |
您所在的位置:网站首页 › 平面经纬图怎么画 › python画经纬度数据库 python经纬度画动态轨迹图 |
作者:J哥 这次呢,我想讲讲地图可视化的内容,以前我也写过用Python的内置库绘制地图,但总感觉不够美观。如何才能在短时间内制作漂亮的可视化地图呢,我觉得Python+可视化工具是不错的选择。 以下动态可视化地图就是我亲手绘制,展现了一段时间内广州市企事业单位在网上商城采购商品的分布及随时间的变化。 接下来,将手把手教你如何绘制这个动态图,数据集文末下载。 数据准备 第一步,打开并预览一下数据集,共766条采购记录,包含采购时间、采购单位和采购金额3个字段。 df = pd.read_excel('cc.xls',index=False) df.head()
第二步,根据采购单位字段获取经纬度,批量获取经纬度的方法很多,详情可参考我往期原创文章「用Python评测三种批量查询经纬度的方法,你pick哪一种?」。 def gaode(addr): para = { 'key':'你的', 'address':addr } url = 'https://restapi.amap.com/v3/geocode/geo?' req = requests.get(url,para) req = req.json() print('-' * 30) if req['status']=='1': if len(req['geocodes']) > 0: m = req['geocodes'][0]['location'] print(m) else: print("None") m = "" else: print("None") return m gaode(addr="广州")应用以上函数并预览数据 df['lat_lon'] = df['buyer'].apply(gaode)2df.head() 长这样:
第三步,对经纬度字段分列并存储为csv格式。 df["lat"] = df["lat_lon"].str.split(',',expand=True)[1] df["lon"] = df["lat_lon"].str.split(',',expand=True)[0] df = df.drop('lat_lon',axis=1) df.to_csv('cc.csv',index=False)简单三步数据准备完毕,数据预览如下:
数据可视化 将以上数据可视化到地图中的方法也有很多,比如Ecahrts、高德地图可视化平台、地图无忧等,本次主要介绍kepler.gl。 kepler.gl是由Uber开发的进行空间数据可视化的开源工具,是Uber内部进行空间数据可视化的默认工具,通过其面向Python开放的接口包keplergl,我们可以在 jupyter notebook 中通过书写Python代码的方式传入多种格式的数据,在其嵌入notebook的交互窗口中使用其内建的多种丰富的空间数据可视化功能。可以让你不需要任何编程基础,即可实现数据地图的可视化。Kepler.gl 支持的数据格式:CSV、GeoJson 和Json。 一、Jupyter中可视化 1. 本地安装 pip install keplergl 注:Windows用户建议conda安装,否则很可能报错。 2. 加载地图和数据
二、在线网站中可视化(推荐) 当然,你也可以直接在kepler官网中上传数据操作,但官网速度较慢,建议用如下网站操作: http://map.guihuayun.com/ #规划云网站搭的一个镜像 打开网站后,首先将cc.csv数据集添加进来。
添加好数据后,可以根据自己的喜好进行图标颜色、大小、地图样式等参数设置。 1. 图标设置
2. 地图样式更改
3. 添加城市轮廓 城市轮廓数据可以在DATAV.GeoAtlas网站进行获取。
4. 上传轮廓数据
5. 添加时间轴
OK,大功告成! 总结 当然,我们还可以利用同样的数据集制作成热力图、3D地图等。关键是,如此便捷实用又美观的地图可视化工具竟然免费!感觉它比目前市面上很多付费工具还要给力。
|
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |