Quantfied Self (QS) Ledger aggregates and visualizes your personal data.
The project has two primary goals:
- download all of your personal data from various tracking services (see below for list of integration services) and store locally.
- provide the starting point for personal data analysis, data visualization and a personal data dashboard
At present, the main objective is to provide working data downloaders and simple data analysis for each of the integrated services.
Some initial work has been started on using these data streams for predictive analytics and forecasting using Machine Learning and Artificial Intelligence, and the intention to increasingly focus on modeling in future iterations. .
- The code is written in Python 3.
- Shared and distributed via Jupyter Notebooks.
- To get started, we recommend downloading and using the Anaconda Distribution.
- For installation, setup and usage of individual services, see documentation provided by each integration.
- Most services depend on Pandas and NumPy for data manipulation and Matplot and Seaborn for data analysis and visualization.
- Each project has a NAME_donwloader and NAME_data_analysis.
- Apple Health: fitness and health tracking and data analysis from iPhone or Apple Watch.
- AutoSleep: iOS sleep tracking data analysis of sleep per night and rolling averages.
- Fitbit: fitness and health tracking and analysis of Steps, Sleep, and Heart Rate from a Fitbit wearable.
- GoodReads: book reading tracking and data analysis for GoodReads.
- Google Calendar: past events, meetings and times for Google Calendar.
- Google Sheets: get data from any Google Sheet which can be useful for pulling data from IFTTT integrations that add data.
- Habitica: habit and task tracking with Habitica's gamified approach to task management.
- Instapaper: articles read and highlighted passages from Instapaper.
- Kindle Highlights: Parser and Highlight Extract from Kindle clippings, along with a sample data analysis and tool to export highlights to separate markdown files.
- Last.fm: music tracking and analysis of music listening history from Last.fm.
- Oura: oura ring activity, sleep and wellness data.
- RescueTime: track computer usage and analysis of computer activities and time with RescueTime.
- Pocket: articles read and read count from Pocket.
- Strava: activities downloader (runs, cycling, swimming, etc.) and analysis from Strava.
- Todoist: task tracking and analysis of todo's and tasks completed history from Todoist app.
- Toggl: time tracking and analysis of manual timelog entries from Toggl.
- WordCounter: extract wordcounter app history and visualize recent periods of word counts.
- Combine and Merge Personal Data into Unified Data Frame: This example notebook provides a step-by-step walkthrough about how to combine multiple data points into a unified daily CSV of personal metrics.
- Simple QS Correlation Explorer with Plot.ly and Dash: This example code uses combined data frame to generate a simple way to view data, visualize correlation and test for linear regression relationship. Requires Dash and Plot.ly.
You can use command line to run jupyter notebooks directly and, in the case of papermill, you can pass parameters:
With nbconvert:
pip install nbconvert
jupyter nbconvert --to notebook --execute --inplace rescuetime/rescuetime_downloader.ipynb
With Papermill:
-
pip install papermill
-
papermill rescuetime_downloader.ipynb data/output.ipynb -p start_date '2019-08-14' -p end_date '2019-10-14'
-
NOTE: You first need to parameterize your notebook in order pass parameters into commands.
Want to help? Fork the project and provide your own data analysis, integration, etc.
Post a ticket in the QS Ledger Issue Queue