当前位置:
首页 > temp > python入门教程 >
-
python绘制高颜值房价与地铁线路分布图
plotly是python非常强大的可视化库,画出的图不仅精美还数据全面,非常适合拿来画地图
今天教大家用plotly库绘制房价和地铁线路分布图,通过本次实例,你能够掌握地图标点、划线的基本用法
plotly的安装比较简单,直接在命令行输入:
pip install plotly
然后需要在官网注册1个token,步骤如下:
1.注册邮箱登录:
2.依次点击Token-Create a token,下方就会出现token值:
pandas读取房价数据:
import pandas as pd
data=pd.read_excel('房价汇总带经纬度.xlsx')
data
房子的经纬度的信息是我根据详细位置用python爬虫爬的,感兴趣的可以自己去试一下
调用go.Scattermapbox()方法,绘制房价散点图:
import plotly.graph_objects as go
token='pk.eyJ1IjoicHl0aG9uYmlyZCIsImEiOiJja2tqOTBneXcwZTlyMnRzNzczNngzY2huIn0.2dImfhmc06Z8IeX6WeNamQ'
fig=go.Figure(go.Scattermapbox(
mode="markers",
lon=data.经度,
lat=data.纬度,
hovertext=data.简介, #悬停显示文本内容
hoverinfo='text',
marker_symbol='marker',
marker_size=6)) #标记大小
fig.update_layout(mapbox={
"accesstoken":token,
"center":{'lon':116.2,'lat':39.56}, #地图中心位置
'zoom':11.8},
margin={'l':0,'r':0,'t':0,"b":0} #地图边距
)
go.Scattermapbox()方法提供了多种symbol样式,网址为:
https://labs.mapbox.com/maki-icons/
但它只能呈现数据位置,表现的很单一
px.scatter_mapbox()则很好的解决这一问题,能够将marker的size和color与不同列的值相关联,通过数据点的位置、颜色和大小多维度地呈现数据(marker的symbol不可改变):
import plotly.express as px
import plotly.graph_objects as go
fig = px.scatter_mapbox(data,
lon = '经度', #输入经度坐标
lat = '纬度', #输入纬度
color ="单价", #对应excel的color栏,每个值代表一种颜色
hover_name ="简介",#可以对应excel里面的某一栏
size_max = 16, #上面size尺寸的最大值
color_continuous_scale = px.colors.carto.Temps
)
fig.update_layout(mapbox = {'accesstoken': token, #需要到官网注册一个token
"center":{'lon':116.2,'lat':39.56}, #指定的地图中心
'zoom': 7.48,
'style': 'dark', #显示的地图类型,有遥感地图,街道地图等类型
},
margin = {'l': 0, 'r': 0, 't': 0, 'b': 0})
fig.show() #显示地图
内置的style可以是[basic, streets, outdoors, light, dark, satellite, satellite-streets]中的任意一种,默认为'light'
最后,我又用爬虫爬了北京市地铁站点信息,代码如下:
import requests
import json
import pandas as pd
url='http://map.amap.com/service/subway?_1599997789354=&srhdata=1100_drw_beijing.json'
response=requests.get(url)
result=json.loads(response.text)
stations=[]
lats=[]
lons=[]
lines=[]
for i in result['l']:
for j in i['st']:
lines.append(i['kn'])
stations.append(j['n'])
lons.append(j['sl'].split(',')[0])
lats.append(j['sl'].split(',')[1])
dataframe=pd.DataFrame({'站名':stations,'线路':lines,'经度':lons,'纬度':lats})
dataframe
在第二张图的基础上加上地铁线路图:
lines=dataframe['线路'].unique().tolist()
for line in lines:
fig.add_traces(go.Scattermapbox(
mode="markers+lines",
lon=dataframe.loc[lambda x:x['线路']==line]['经度'],
lat=dataframe.loc[lambda x:x['线路']==line]['纬度'],
hovertext=dataframe.loc[lambda x:x['线路']==line]['站名'],
hoverinfo='text',
marker_symbol='marker',
marker_size=6,
showlegend = False))
for line in lines[1:]:
fig.add_traces(go.Scattermapbox(
mode="markers+lines",
lon=dataframe.loc[lambda x:x['线路']==line]['经度'],
lat=dataframe.loc[lambda x:x['线路']==line]['纬度'],
hovertext=dataframe.loc[lambda x:x['线路']==line]['站名'],
hoverinfo='text',
marker_symbol='marker',
marker_size=6,
showlegend = False))
fig.update_layout(mapbox={"accesstoken":token,"center":{'lon':116.2,'lat':39.56},'zoom':11.8},
margin={'l':0,'r':0,'t':0,"b":0})
大功告成,你学会了吗?
出 处:https://www.cnblogs.com/python147/p/14473994.html
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数