这次呢,我想讲讲地图可视化的内容,以前我也写过用Python的内置库绘制地图,但总感觉不够美观。如何才能在短时间内制作漂亮的可视化地图呢,我觉得Python+可视化工具是不错的选择。
以下动态可视化地图就是J哥亲手绘制,展现了一段时间内广州市企事业单位在网上商城采购商品的分布及随时间的变化。
接下来,J哥将手把手教你如何绘制这个动态图,您可在公众号后台回复「cc」获取数据集进行测试。
数据准备
第一步,打开并预览一下数据集,共766条采购记录,包含采购时间、采购单位和采购金额3个字段。
1df=pd.read_excel('cc.xls',index=False)2df.head()
第二步,根据采购单位字段获取经纬度,批量获取经纬度的方法很多,详情可参考J哥往期原创文章「用Python评测三种批量查询经纬度的方法,你pick哪一种?」。
1defgaode(addr):2para={3'key':'你的',4'address':addr5}6url='/v3/geocode/geo?'7req=requests.get(url,para)8req=req.json()9print('-'*30)10ifreq['status']=='1':11iflen(req['geocodes'])>0:12m=req['geocodes'][0]['location']13print(m)14else:15print("None")16m=""17else:18print("None")1920returnm21gaode(addr="广州")
应用以上函数并预览数据
1df['lat_lon']=df['buyer'].apply(gaode)2df.head()
长这样:
第三步,对经纬度字段分列并存储为csv格式。
1df["lat"]=df["lat_lon"].str.split(',',expand=True)[1]2df["lon"]=df["lat_lon"].str.split(',',expand=True)[0]3df=df.drop('lat_lon',axis=1)4df.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.本地安装
pipinstallkeplergl
注:Windows用户建议conda安装,否则很可能报错。
2.加载地图和数据
二、在线网站中可视化(推荐)
当然,你也可以直接在kepler官网中上传数据操作,但官网速度较慢,建议用如下网站操作:
/#规划云网站搭的一个镜像
打开网站后,首先将cc.csv数据集添加进来。
添加好数据后,可以根据自己的喜好进行图标颜色、大小、地图样式等参数设置。
1.图标设置
2.地图样式更改
3.添加城市轮廓
城市轮廓数据可以在DATAV.GeoAtlas网站进行获取。
4.上传轮廓数据
5.添加时间轴
OK,大功告成!
总结
当然,我们还可以利用同样的数据集制作成热力图、3D地图等。关键是,如此便捷实用又美观的地图可视化工具竟然免费!感觉它比目前市面上很多付费工具还要给力。
由于微信平台算法改版,公号内容将不再以时间排序展示,如果大家想第一时间看到我们的推送,强烈建议星标我们和给我们多点点【在看】。星标具体步骤为:(1)点击页面最上方“小詹学Python”,进入公众号主页。(2)点击右上角的小点点,在弹出页面点击“设为星标”,就可以啦。感谢支持,比心。