只需在此处添加它以防万一。Strava API 还能够下载数据流(请参阅此处的API 文档)。我相信这会提供更多信息,例如隐私区域内的私人活动和 GPX 点等。假设 API 范围设置为 read_all。
我将 API 与 Python 一起使用,但我认为它在 Java 中的工作原理基本相同。另请注意,我只是将其作为一种爱好,因此可能有一种更有效的方法来执行以下操作...
此处提供有关创建 gpx 文件的示例
下面的代码应该从 Strava API 下载数据流,然后从这些数据流生成 GPX 文件。
import requests as r
import pandas as pd
import json
import gpxpy.gpx
from datetime import datetime, timedelta
#This info is in activity summary downloaded from API
id = 12345678 #activity ID
start_time = '2022-01-01T12:04:10Z' #activity start_time_local
#get access token for API
with open('config/strava_tokens.json') as f:
strava_tokens = json.load(f)
access_token = strava_tokens['access_token']
# Make API call
url = f"https://www.strava.com/api/v3/activities/{id}/streams"
header = {'Authorization': 'Bearer ' + access_token}
latlong = r.get(url, headers=header, params={'keys':['latlng']}).json()[0]['data']
time_list = r.get(url, headers=header, params={'keys':['time']}).json()[1]['data']
altitude = r.get(url, headers=header, params={'keys':['altitude']}).json()[1]['data']
# Create dataframe to store data 'neatly'
data = pd.DataFrame([*latlong], columns=['lat','long'])
data['altitude'] = altitude
start = datetime.strptime(start_time, "%Y-%m-%dT%H:%M:%SZ")
data['time'] = [(start+timedelta(seconds=t)) for t in time_list]
gpx = gpxpy.gpx.GPX()
# Create first track in our GPX:
gpx_track = gpxpy.gpx.GPXTrack()
gpx.tracks.append(gpx_track)
# Create first segment in our GPX track:
gpx_segment = gpxpy.gpx.GPXTrackSegment()
gpx_track.segments.append(gpx_segment)
# Create points:
for idx in data.index:
gpx_segment.points.append(gpxpy.gpx.GPXTrackPoint(
data.loc[idx, 'lat'],
data.loc[idx, 'long'],
elevation=data.loc[idx, 'altitude'],
time=data.loc[idx, 'time']
))
# Write data to gpx file
with open('output.gpx', 'w') as f:
f.write(gpx.to_xml())
我刚刚向 GitHub 添加了一个 python 代码,希望可以从 Strava 下载所有用户的 GPX 文件。