<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          太震撼了,我用python畫出全北京的公交線路動圖

          共 8015字,需瀏覽 17分鐘

           ·

          2020-09-09 17:39

          今天教大家用pyecharts制作北京市公交線路動態(tài)圖,這應(yīng)該是全網(wǎng)唯一一篇能正常運行的教程

          一、獲取百度秘鑰

          首先,本項目需要引用百度地圖api,所以需要先注冊獲取百度開放平臺秘鑰,地址為:

          http://lbsyun.baidu.com/apiconsole/key#

          有賬號的直接登錄,沒賬號的先注冊一下再登錄,登錄完成后,依次點擊控制臺-應(yīng)用管理-我的應(yīng)用-創(chuàng)建應(yīng)用:

          訪問應(yīng)用(AK)下即是我們這次所需的秘鑰

          二、整理公交車地理數(shù)據(jù)

          這個公交車地理數(shù)據(jù)著實有點坑,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 < busLine.length; 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ù)位依次相加,兩兩一組即為各個公交站點地理坐標,每個列表代表1個線路。

          用python實現(xiàn)以上過程,代碼如下:

          import json
          with open('1.json','r'as f:
              datas=json.load(f)
          result=[]
          for data in datas:
              data = [float(i / 10000for 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.4040.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.4040.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()
             

          大家覺得哪一種更好看呢?歡迎在評論區(qū)留言

          公交線路數(shù)據(jù)和完整代碼點擊閱讀原文或下方鏈接https://yihang.cowtransfer.com/s/52151c39d60a4d

             

          推薦閱讀

          (點擊標題可跳轉(zhuǎn)閱讀)

          同濟版《線性代數(shù)》引發(fā)激烈爭議!

          介紹一款分享真實互聯(lián)網(wǎng)薪資的小程序

          再見,正則表達式


          轉(zhuǎn)了嗎
                                             
                                     贊了嗎
          在看嗎
          瀏覽 58
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  中文字幕一区二区三区四区五区人 | 久久久久久这里只有好吊视频 | 搔视频网址在线观看 | 国产乱婬片A片AAAAPp地址 | 影音先锋成人无码影院 |