Я использую библиотеку Fitbit Python для подключения к API FitBit: https://github.com/orcasgit/python-fitbit
Я не очень знаком с FitBit, но я считаю, что я на правильном пути для того, что я пытаюсь сделать.
У меня есть данные, которые выглядят так:
{u'activities': [],
u'goals':
{u'activeMinutes': 30, u'distance': 5, u'caloriesOut': 2364, u'steps': 10000},
u'summary':
{u'distances':
[{u'distance': 3.49, u'activity': u'total'},
{u'distance': 3.49, u'activity': u'tracker'},
{u'distance': 0, u'activity': u'loggedActivities'},
{u'distance': 1.27, u'activity': u'veryActive'},
{u'distance': 0.22, u'activity': u'moderatelyActive'},
{u'distance': 2, u'activity': u'lightlyActive'},
{u'distance': 0, u'activity': u'sedentaryActive'}],
u'sedentaryMinutes': 394,
u'lightlyActiveMinutes': 153,
u'caloriesOut': 1547,
u'caloriesBMR': 942,
u'marginalCalories': 414,
u'fairlyActiveMinutes': 8,
u'veryActiveMinutes': 29,
u'activityCalories': 750,
u'steps': 8277,
u'activeScore': -1}}'
Обычно не все в одной строке, но я возвратил каждую строку, чтобы было легче читать.
Iя пытаюсь вернуть только пару строк в столбцы в CSV, который будет выглядеть следующим образом:
![enter image description here](https://i.stack.imgur.com/Ts2lp.png)
Вот код, который у меня есть, большинствоэто извлечено из этого веб-сайта, и я изменил его так, чтобы он извлекал активность вместо сводки сна: https://towardsdatascience.com/collect-your-own-fitbit-data-with-python-ff145fa10873
import fitbit
import gather_keys_oauth2 as Oauth2
import pandas as pd
import datetime
import csv
CLIENT_ID = '22CZ94'
CLIENT_SECRET = '06a52bc5d8239790f630ffdd19377ba2'
server = Oauth2.OAuth2Server(CLIENT_ID, CLIENT_SECRET)
server.browser_authorize()
ACCESS_TOKEN = str(server.fitbit.client.session.token['access_token'])
REFRESH_TOKEN = str(server.fitbit.client.session.token['refresh_token'])
auth2_client = fitbit.Fitbit(CLIENT_ID, CLIENT_SECRET, access_token='eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiI2V0gyTlAiLCJhdWQiOiIyMkNaOTQiLCJpc3MiOiJGaXRiaXQiLCJ0eXAiOiJhY2Nlc3NfdG9rZW4iLCJzY29wZXMiOiJyc29jIHJzZXQgcmFjdCBybG9jIHJ3ZWkgcmhyIHJwcm8gcm51dCByc2xlIiwiZXhwIjoxNTY5Mjc5OTAxLCJpYXQiOjE1Mzc3NDM5MDF9.1StrKUUJwidejZ2pbCZzkIBG8FztQiLMvBql6fgEpaY', refresh_token=REFRESH_TOKEN)
fit_statsSum = auth2_client.activities(date='2018-09-25')['activities'][0]
actsummarypdf = pd.DataFrame({'SedentaryMinutes':fit_statsSum[u'sedentaryMinutes'],
'lightlyActiveMinutes':fit_statsSum['lightlyActiveMinutes'],
'fairlyActiveMinutes':fit_statsSum['fairlyActiveMinutes'],
'veryActiveMinutes':fit_statsSum['veryActiveMinutes'],
'steps':fit_statsSum['steps']
})
actsummarypdf.to_csv('c:\python-fitbit-master\Activities' + '2018-09-25' + '.csv')
С таким кодом я получаю:
Traceback (most recent call last):
File ".\autho2_activity_summary.py", line 28, in <module>
fit_statsSum = auth2_client.activities(date='2018-09-25')['activities'][0]
IndexError: list index out of range
Если яудалите [0], я получу:
Traceback (most recent call last):
File ".\autho2_activity_summary.py", line 30, in <module>
actsummarypdf =
pd.DataFrame({'SedentaryMinutes':fit_statsSum['sedentaryMinutes'],
TypeError: list indices must be integers or slices, not str
я также попытался использовать u'sedentaryMinutes 'и "u'sedentaryMinutes'", но без изменений.
Любая помощь по тому, что мне не хватаетбыл бы очень признателен.