python获取高德地图实时交通状况,并在arggis上可视化

代码:

# -*- coding: utf-8 -*-
"""
Created on Thu Sep  5 23:27:32 2019

@author: 16534
"""


import requests

import pandas as pd

import json

import time

#初始API的URL

 

url="https://restapi.amap.com/v3/traffic/status/rectangle?key=3112295ad0404c2da3b4dca3a5465b01&extensions=all&rectangle="

 

#设定整个网格左下角坐标的经纬度值

#baselng=108.772376

baselng=121.2

#baselat=34.177000
baselat=31.1

 

#设定每个网格单元的经纬度宽

 

widthlng=0.05

 

widthlat=0.04

 

#用于储存数据

 

x=[]

 

#用于标识交通态势线段

 

num=0

#爬取过程可能会出错中断,因此增加异常处理

 

try:

#循环每个网格进行数据爬取,在这里构建了3X3网格

 

    for i in range(0,5):

 

        #设定网格单元的左下与右上坐标的纬

  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
爬取高德地图数据可以使用`requests`库和`BeautifulSoup`库。首先,需要获取全国地铁列表页面的HTML内容。可以通过以下代码实现: ```python import requests from bs4 import BeautifulSoup url = 'https://ditie.mapbar.com' response = requests.get(url) soup = BeautifulSoup(response.text, 'html.parser') ``` 接下来,需要从HTML中提取地铁信息。可以通过观察HTML源代码,发现地铁信息保存在`<div class="subway_list">`标签下的`<a>`标签中。可以使用以下代码提取地铁名称和链接: ```python subway_list = soup.find('div', {'class': 'subway_list'}) subways = subway_list.find_all('a') subway_info = [] for subway in subways: name = subway.text link = subway['href'] subway_info.append({'name': name, 'link': link}) ``` 接下来,需要访问每个地铁线路的页面获取地铁站点信息。可以使用以下代码实现: ```python for subway in subway_info: link = subway['link'] response = requests.get(link) soup = BeautifulSoup(response.text, 'html.parser') station_list = soup.find('div', {'class': 'station_list'}) stations = station_list.find_all('a') station_info = [] for station in stations: name = station.text lat = station['lat'] lng = station['lng'] station_info.append({'name': name, 'lat': lat, 'lng': lng}) subway['stations'] = station_info ``` 现在,`subway_info`列表就包含了全国所有地铁线路的信息,每个地铁线路包含它所包含的地铁站点信息。可以将这些信息写入CSV文件中: ```python import csv with open('subway.csv', 'w', newline='', encoding='utf-8') as csvfile: fieldnames = ['subway', 'station', 'lat', 'lng'] writer = csv.DictWriter(csvfile, fieldnames=fieldnames) writer.writeheader() for subway in subway_info: for station in subway['stations']: writer.writerow({ 'subway': subway['name'], 'station': station['name'], 'lat': station['lat'], 'lng': station['lng'] }) ``` 数据可视化可以使用`matplotlib`库和`pandas`库。可以使用以下代码读取CSV文件并创建一个包含所有地铁站点信息的数据框: ```python import pandas as pd df = pd.read_csv('subway.csv') ``` 接下来,可以使用以下代码绘制全国地铁站点分布图: ```python import matplotlib.pyplot as plt plt.figure(figsize=(10, 8)) plt.scatter(df['lng'], df['lat'], s=2, alpha=0.5) plt.title('Subway stations in China') plt.xlabel('Longitude') plt.ylabel('Latitude') plt.show() ``` 可以在地图上看到所有地铁站点的分布情况。如果想要根据地铁线路对站点进行着色,可以使用以下代码: ```python import matplotlib.cm as cm colors = cm.rainbow(df['subway'].factorize()[0] / len(df['subway'].unique())) plt.figure(figsize=(10, 8)) plt.scatter(df['lng'], df['lat'], s=2, alpha=0.5, c=colors) plt.title('Subway stations in China') plt.xlabel('Longitude') plt.ylabel('Latitude') plt.show() ``` 这样可以看到每个地铁线路的站点都被着不同的颜色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值