Skip to content

UnexpectedMaker/micropython-youtube-api

Repository files navigation

MicroPython Youtube API

A MicroPython based Youtube API wrapper library and example code that allows you to connect to the Google Apps API backend to obtain channel stats for aa YouTube channel.

Setting up the config.json

The config.json file contains entried you will need to fill in for the following items: * ssid - Your Wifi network SSID * ssid_password - Your WiFi router password * appkeyid - Your API kety from Google (See below on how to opbtain one) * channelid - Your YouTube Channel ID * query_interval_sec - How long between hitting GoogleApps for an updated set of data

{
    "ssid": "Enter_Wifi_SSID",
    "ssid_password": "Enter_Wifi_Password",
    "appkeyid": "Enter_GooleApps_API_Key",
    "channelid": "Enter_YT_Channel_ID",
    "query_interval_sec": 60
}

Installing

Download the repositry and copy the following files to your ESP8266 or ESP32 Development board running the latest mainline MicroPython firmware

  • micropython_youtube_api.py
  • config.json
  • urequests.py
  • Optional: grab_stats.py from examples folder

Using the API

Check the grab_stats.py example script for a full implementation of using the library.

Take note that the creation of the YoutubeAPI() instance is done using the with statement to create a context around the definition, so cleanup of the WiFi connection can happen when the data variable (class instance) is out of scope.

from micropython_youtube_api import YoutubeAPI
import network, json, time

# Read config
with open('config.json') as f:
    config = json.load(f)

# Check config.json has updated credentials
if config['ssid'] == 'Enter_Wifi_SSID':
    assert False, ("config.json has not been updated with your unique keys and data")

# Create WiFi connection and turn it on
wlan = network.WLAN(network.STA_IF)
wlan.active(True)

# Connect to WiFi router
print ("Connecting to WiFi: {}".format( config['ssid'] ) )
wlan.connect( config['ssid'], config['ssid_password'])

# Wait until wifi is connected
while not wlan.isconnected:
    pass

# Create an instance of the YoutubeApi
with YoutubeAPI( config["channelid"], config["appkeyid"], config["query_interval_sec"] ) as data:

    # Read the data every X seconds
    update_interval = 5
    update_stats_time = time.time() - 10

    while True:

        if update_stats_time < time.time():
            update_stats_time = time.time() + update_interval

            print ("Subs {}".format( data.subs ) )
            print ("Views {}".format( data.views ) )
            print ("Videos {}".format( data.videos ) )
            print ("Comments {}".format( data.comments ) )

Getting a Google Apps API key (Required!)

https://www.googleapis.com/youtube/v3/channels?part=statistics&id=UCu7_D0o48KbfhpEohoP7YSQ&key=PutYourNewlyGeneratedKeyHere

Enjoy!

Back me on Patreon?

I love making and designing projects but sharing open source projects takes a lot of thought and time. I do it because I think it’s important to share knowledge and give back to the community like many have done before me.

If you find this project useful or want to see more open source projects like it, please consider backing me on Patreon to say thanks!

Patreon

https://www.patreon.com/unexpectedmaker

Unexpected Maker

http://youtube.com/c/unexpectedmaker

http://twitter.com/unexpectedmaker

https://www.facebook.com/unexpectedmaker/

https://www.instagram.com/unexpectedmaker/

https://www.tindie.com/stores/seonr/