Skip to content

Instantly share code, notes, and snippets.

@MattJermyWright
Last active February 2, 2016 16:27
Show Gist options
  • Save MattJermyWright/b6b3f92b992266203e25 to your computer and use it in GitHub Desktop.
Save MattJermyWright/b6b3f92b992266203e25 to your computer and use it in GitHub Desktop.
Youtube Analytics API Pulls
#!/usr/bin/env python
# Original taken from https://developers.google.com/youtube/analytics/v1/code_samples/python
# Prereq Installs:
# pip install httplib2
# pip install apiclient
# pip install urllib3
# pip install --upgrade google-api-python-client
# pip install --upgrade oauth2client
from datetime import datetime, timedelta
import httplib2
import os
import sys
from apiclient.discovery import build
from oauth2client.file import Storage
from oauth2client.client import flow_from_clientsecrets
from oauth2client.tools import run
from optparse import OptionParser
# CLIENT_SECRETS_FILE, name of a file containing the OAuth 2.0 information for
# this application, including client_id and client_secret. You can acquire an
# ID/secret pair from the API Access tab on the Google APIs Console
# http://code.google.com/apis/console#access
# For more information about using OAuth2 to access Google APIs, please visit:
# https://developers.google.com/accounts/docs/OAuth2
# For more information about the client_secrets.json file format, please visit:
# https://developers.google.com/api-client-library/python/guide/aaa_client_secrets
# Please ensure that you have enabled the YouTube Data & Analytics APIs for your project.
CLIENT_SECRETS_FILE = "client_secrets.json"
# We will require read-only access to the YouTube Data and Analytics API.
YOUTUBE_SCOPES = ["https://www.googleapis.com/auth/youtube.readonly",
"https://www.googleapis.com/auth/yt-analytics.readonly"]
YOUTUBE_API_SERVICE_NAME = "youtube"
YOUTUBE_API_VERSION = "v3"
YOUTUBE_ANALYTICS_API_SERVICE_NAME = "youtubeAnalytics"
YOUTUBE_ANALYTICS_API_VERSION = "v1"
# Helpful message to display if the CLIENT_SECRETS_FILE is missing.
MISSING_CLIENT_SECRETS_MESSAGE = """
WARNING: Please configure OAuth 2.0
To make this sample run you will need to populate the client_secrets.json file
found at:
%s
with information from the APIs Console
https://code.google.com/apis/console#access
For more information about the client_secrets.json file format, please visit:
https://developers.google.com/api-client-library/python/guide/aaa_client_secrets
""" % os.path.abspath(os.path.join(os.path.dirname(__file__),
CLIENT_SECRETS_FILE))
now = datetime.now()
one_day_ago = (now - timedelta(days=1)).strftime("%Y-%m-%d")
one_week_ago = (now - timedelta(days=7)).strftime("%Y-%m-%d")
parser = OptionParser()
parser.add_option("--metrics", dest="metrics", help="Report metrics",
default="views,comments,favoritesAdded,favoritesRemoved,likes,dislikes,shares")
parser.add_option("--dimensions", dest="dimensions", help="Report dimensions",
default="video")
parser.add_option("--start-date", dest="start_date",
help="Start date, in YYYY-MM-DD format", default=one_week_ago)
parser.add_option("--end-date", dest="end_date",
help="End date, in YYYY-MM-DD format", default=one_day_ago)
parser.add_option("--start-index", dest="start_index", help="Start index",
default=1, type="int")
parser.add_option("--max-results", dest="max_results", help="Max results",
default=10, type="int")
parser.add_option("--sort", dest="sort", help="Sort order", default="-views")
(options, args) = parser.parse_args()
flow = flow_from_clientsecrets(CLIENT_SECRETS_FILE,
message=MISSING_CLIENT_SECRETS_MESSAGE,
scope=" ".join(YOUTUBE_SCOPES))
storage = Storage("%s-oauth2.json" % sys.argv[0])
credentials = storage.get()
if credentials is None or credentials.invalid:
credentials = run(flow, storage)
http = credentials.authorize(httplib2.Http())
#youtube = build(YOUTUBE_API_SERVICE_NAME, YOUTUBE_API_VERSION, http=http)
youtube_analytics = build(YOUTUBE_ANALYTICS_API_SERVICE_NAME,
YOUTUBE_ANALYTICS_API_VERSION, http=http)
analytics_response = youtube_analytics.reports().query(
ids="channel==UCqcEzOKaA4nc0gISklN0Ryw",
filters="video==%s" % "t7v_7keCQf0",
metrics="audienceWatchRatio,relativeRetentionPerformance",
dimensions="elapsedVideoTimeRatio",
start_date="2014-11-01",
end_date="2014-11-30"
).execute()
for column_header in analytics_response.get("columnHeaders", []):
print "%-20s" % column_header["name"],
print
for row in analytics_response.get("rows", []):
for value in row:
print "%-20s" % value,
print
analytics_response2 = youtube_analytics.reports().query(
ids="channel==UCqcEzOKaA4nc0gISklN0Ryw",
filters="video==%s" % "t7v_7keCQf0",
# metrics="estimatedMinutesWatched,views,averageViewPercentage,averageViewDuration",
metrics="views,estimatedMinutesWatched",
dimensions="day,insightPlaybackLocationType",
sort="day",
start_date="2014-11-01",
end_date="2014-11-30"
).execute()
for column_header in analytics_response2.get("columnHeaders", []):
print "%-20s" % column_header["name"],
print
for row in analytics_response2.get("rows", []):
for value in row:
print "%-20s" % value,
print
analytics_response3 = youtube_analytics.reports().query(
ids="channel==UCqcEzOKaA4nc0gISklN0Ryw",
filters="video==%s" % "t7v_7keCQf0",
# metrics="views,averageViewPercentage,averageViewDuration",
metrics="views,estimatedMinutesWatched,averageViewDuration,averageViewPercentage",
dimensions="day",
sort="day",
start_date="2014-11-01",
end_date="2014-11-30"
).execute()
for column_header in analytics_response3.get("columnHeaders", []):
print "%-20s" % column_header["name"],
print
for row in analytics_response3.get("rows", []):
for value in row:
print "%-20s" % value,
print
#channels_response = youtube.channels().list(
# mine=True,
# part="id"
#).execute()
# for channel in channels_response.get("items", []):
# channel_id = channel["id"]
# analytics_response = youtube_analytics.reports().query(
# ids="channel==%s" % channel_id,
# metrics=options.metrics,
# dimensions=options.dimensions,
# start_date=options.start_date,
# end_date=options.end_date,
# start_index=options.start_index,
# max_results=options.max_results,
# sort=options.sort
# ).execute()
# print "Analytics Data for Channel %s" % channel_id
# for column_header in analytics_response.get("columnHeaders", []):
# print "%-20s" % column_header["name"],
# print
# for row in analytics_response.get("rows", []):
# for value in row:
# print "%-20s" % value,
# print
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment