用python畫一幅全北京的公交線路動(dòng)圖
今天教大家用pyecharts制作北京市公交線路動(dòng)態(tài)圖。這個(gè)可視化的效果很有意思,如下圖所示:

接下來,我們講下要如何實(shí)現(xiàn)。
一、獲取百度秘鑰
首先,本項(xiàng)目需要引用百度地圖api,所以需要先注冊(cè)獲取百度開放平臺(tái)秘鑰,地址為:
http://lbsyun.baidu.com/apiconsole/key#有賬號(hào)的直接登錄,沒賬號(hào)的先注冊(cè)一下再登錄,登錄完成后,依次點(diǎn)擊控制臺(tái)-應(yīng)用管理-我的應(yīng)用-創(chuàng)建應(yīng)用:

訪問應(yīng)用(AK)下即是我們這次所需的秘鑰
二、整理公交車地理數(shù)據(jù)
這個(gè)公交車地理數(shù)據(jù)著實(shí)有點(diǎn)坑,echarts官方給的數(shù)據(jù)長這樣:

看起來好像密碼,真讓人頭大
只好硬著頭皮去研究一下官方代碼:
$.getJSON(uploadedDataURL,?function(data)?{
????var?hStep?=?300?/?(data.length?-?1);
????var?busLines?=?[].concat.apply([],?data.map(function?(busLine,?idx)?{
????????var?prevPt;
????????var?points?=?[];
????????for?(var?i?=?0;?i?2)?{
????????????var?pt?=?[busLine[i],?busLine[i?+?1]];
????????????if?(i?>?0)?{
????????????????pt?=?[
????????????????????prevPt[0]?+?pt[0],
????????????????????prevPt[1]?+?pt[1]
????????????????];
????????????}
????????????prevPt?=?pt;
????????????points.push([pt[0]?/?1e4,?pt[1]?/?1e4]);
????????}
????????return?{
????????????coords:?points,
????????????lineStyle:?{
????????????????normal:?{
????????????????????color:?echarts.color.modifyHSL('#5A94DF',?Math.round(hStep?*?idx))
????????????????}
????????????}
????????}
這是一段java代碼,如果看不懂就不要看了,大致意思是把數(shù)據(jù)都除以10000,然后列表奇數(shù)位依次相加、偶數(shù)位依次相加,兩兩一組即為各個(gè)公交站點(diǎn)地理坐標(biāo),每個(gè)列表代表1個(gè)線路。
用python實(shí)現(xiàn)以上過程,代碼如下:
import?json
with?open('1.json','r')?as?f:
????datas=json.load(f)
result=[]
for?data?in?datas:
????data?=?[float(i?/?10000)?for?i?in?data]
????a=[]
????for?i?in?range(2,len(data),2):
????????data[i]=data[i-2]+data[i]
????????data[i+1]?=?data[i?-?1]?+?data[i+1]
????????a.append([data[i],data[i+1]])
????result.append(a)
感覺還是python的代碼要少一些……
三、畫圖
這里給大家提供兩種方式
1.帶地圖背景的
BAIDU_MAP_AK?=?"輸入你自己的秘鑰"
c?=?(
????BMap(init_opts=opts.InitOpts(width="1200px",?height="800px"))
????.add_schema(
????????baidu_ak=BAIDU_MAP_AK,
????????center=[116.40,?40.04],
????????zoom=10,
????????is_roam=True,
????)
????.add(
????????"",
????????type_="lines",
????????is_polyline=True,
????????data_pair=result,
????????linestyle_opts=opts.LineStyleOpts(opacity=0.2,?width=0.5,color='red'),
????????#?如果不是最新版本的話可以注釋下面的參數(shù)(效果差距不大)
????????progressive=200,
????????progressive_threshold=500,
????)
)
c.render_notebook()
2.不帶地圖背景的
BAIDU_MAP_AK?=?"輸入你自己的秘鑰"
c?=?(
????BMap(init_opts=opts.InitOpts(width="1200px",?height="800px"))
????.add_schema(
????????baidu_ak=BAIDU_MAP_AK,
????????center=[116.40,?40.04],
????????zoom=10,
????????is_roam=True,
????????map_style={
????????????"styleJson":?[
????????????????{
????????????????????"featureType":?"water",
????????????????????"elementType":?"all",
????????????????????"stylers":?{"color":?"#031628"},
????????????????},
???????????????
?????????? “省略部分修飾代碼”
????)
????.add(
????????"",
????????type_="lines",
????????is_polyline=True,
????????data_pair=result,
????????linestyle_opts=opts.LineStyleOpts(opacity=0.2,?width=0.5,color='red'),
????????#?如果不是最新版本的話可以注釋下面的參數(shù)(效果差距不大)
????????progressive=200,
????????progressive_threshold=500,
????)
)
c.render_notebook()

大家覺得哪一種更好看呢?歡迎在評(píng)論區(qū)留言
_往期文章推薦_
評(píng)論
圖片
表情
