Skip to main content

Wasted On Youtube

Project description

woy - Wasted On Youtube

License PyPI Python Version

asciicast

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

woy-1.0.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

woy-1.0-py3-none-any.whl (19.4 kB view details)

Uploaded Python 3

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

Hashes for woy-1.0.tar.gz
Algorithm Hash digest
SHA256 45a15041ceafe879c6149ad4c2f944c5ccaff1107db73348aec1328c5285dc79
MD5 8d28a02678131767856f380cccb69200
BLAKE2b-256 a29d9d948c532614835704433cb9ada457051ae23c2506372b6eefa9dd429a66

See more details on using hashes here.

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

Hashes for woy-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 559f2efca2a9dad4b8420cec42134344097de4cb40091611b46ba67fb539a80a
MD5 810a8446d27af2af37cd6ccb5da4ab4a
BLAKE2b-256 c8a47f717ff91f8a704127f14cbe81c7d4beb876dc154b14e70c3554e48357cd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page