Wasted On Youtube
Project description
woy - Wasted On Youtube
Wanna know how badly addicted you are to youtube? Woy will tell you how much of your time you wasted watching videos, with several stats about channels, tags, weekly watchtime, and so on.
It works by scraping your youtube watch history (obtained with Google Takeout) and complementing with extra info about the videos (obtained with the Youtube API).
Setup
First, ask google for your data with Google Takeout. You can deselect everything except Youtube. After selecting Youtube, make sure to click on "multiple formats" and change the "history" dropdown from HTML to JSON. Do whatever you prefer for the next steps, and you should soon receive your data via the chosen method.
The history file will be located at Takeout/YouTube and YouTube Music/history/watch-history.json inside the extracted directory.
In order to use the youtube API you'll need your own API key (or alternative, ask for a friend's 😉). To do so, I recommend following the official guide up to point 3.; you can skip setting up OAuth authentication, as it won't be needed.
Once you have your Takeout and your API key, you're ready to go! Install woy with pip (or your preferred method, I suggest uv):
pip install woy
Usage
To scrape your history and download the additional info, run:
woy fetch <PATH_TO_TAKEOUT_HISTORY_JSON> <API_KEY>
[!WARNING] By default your API will have a quota of 10k requests per day. This should be plenty for this purpose, as woy tries to be smart about it and batch requests, but you won't be able to use the same API key many times in the same day. That should be ok though, since you only need to do this once! Anyway, you'll get a confirmation prompt telling you how much api quota this run will use.
This will create a file called youtube_watch_history.csv in the current directory with all the history data. Feel free to peruse it and a analyse it however you like!
To generate a summary, prepare to cringe and run:
woy process
[!TIP] Video titles and channel names are clickable links!
Run woy process -h to see all the available options to customize the summary.
For example, to include only the data starting from 2020, and exclude videos categorized as "Music", run:
woy process --exclude-categories "Music" -f 2020-01-01
Caveats
Youtube Takeout unfortunately does not include playback information, such as exact minutes watched and playback speed. This means that every time a video is watched "a bit", it's counted as a full watch. As a result, watch times are always overestimated, resulting for example in days where the watchtime is longer than 24h. As far as I know, there's no way around it.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file woy-1.0.tar.gz.
File metadata
- Download URL: woy-1.0.tar.gz
- Upload date:
- Size: 21.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
45a15041ceafe879c6149ad4c2f944c5ccaff1107db73348aec1328c5285dc79
|
|
| MD5 |
8d28a02678131767856f380cccb69200
|
|
| BLAKE2b-256 |
a29d9d948c532614835704433cb9ada457051ae23c2506372b6eefa9dd429a66
|
File details
Details for the file woy-1.0-py3-none-any.whl.
File metadata
- Download URL: woy-1.0-py3-none-any.whl
- Upload date:
- Size: 19.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
559f2efca2a9dad4b8420cec42134344097de4cb40091611b46ba67fb539a80a
|
|
| MD5 |
810a8446d27af2af37cd6ccb5da4ab4a
|
|
| BLAKE2b-256 |
c8a47f717ff91f8a704127f14cbe81c7d4beb876dc154b14e70c3554e48357cd
|