Compare commits
2 Commits
f0dbb580b2
...
5d58428cd9
Author | SHA1 | Date | |
---|---|---|---|
5d58428cd9 | |||
1f5eaa231a |
@ -29,8 +29,23 @@ class YouTubeAPI(object):
|
|||||||
channel = snippet['channelTitle']
|
channel = snippet['channelTitle']
|
||||||
channelId = snippet['channelId']
|
channelId = snippet['channelId']
|
||||||
description = snippet['description']
|
description = snippet['description']
|
||||||
tags = snippet['tags']
|
try:
|
||||||
|
tags = snippet['tags']
|
||||||
|
except:
|
||||||
|
tags = ''
|
||||||
privacy = status['privacyStatus']
|
privacy = status['privacyStatus']
|
||||||
return title, date, channel, channelId, description, tags, privacy
|
return title, date, channel, channelId, description, tags, privacy
|
||||||
|
|
||||||
|
def getPlaylist(self, id, pageToken=''):
|
||||||
|
if(pageToken):
|
||||||
|
pageToken = '&pageToken={}'.format(pageToken)
|
||||||
|
return self.getRequest('playlistItems?part=snippet&maxResults=50&playlistId={}{}'.format(id,
|
||||||
|
pageToken))
|
||||||
|
|
||||||
|
def getPlaylistVideos(self, id):
|
||||||
|
playlist = self.getPlaylist(id)
|
||||||
|
items = playlist['items']
|
||||||
|
while 'nextPageToken' in playlist:
|
||||||
|
playlist = self.getPlaylist(id, playlist['nextPageToken'])
|
||||||
|
items.extend(playlist['items'])
|
||||||
|
return items
|
||||||
|
@ -2,16 +2,36 @@
|
|||||||
|
|
||||||
from youtube_api import YouTubeAPI
|
from youtube_api import YouTubeAPI
|
||||||
import sys
|
import sys
|
||||||
|
import youtube_dl
|
||||||
|
|
||||||
# Read YouTube API Key
|
# Read YouTube API Key.
|
||||||
def getYouTubeAPIKey():
|
def getYouTubeAPIKey():
|
||||||
return open('youtube.key', 'r').read()
|
return open('youtube.key', 'r').read()
|
||||||
|
|
||||||
|
def getUploadTime(info):
|
||||||
|
return info[1]
|
||||||
|
|
||||||
|
def getYear(info):
|
||||||
|
return int(getUploadTime(info)[:4])
|
||||||
|
|
||||||
|
def getPrivacy(info):
|
||||||
|
return info[6]
|
||||||
|
|
||||||
|
# Print out information about a video.
|
||||||
|
def printVideoInfo(info):
|
||||||
|
title, date, channel, channelId, description, tags, privacy = info
|
||||||
|
print('Title: ' + title)
|
||||||
|
print('Date: ' + date)
|
||||||
|
print('Channel: {} ({})'.format(channel, channelId) )
|
||||||
|
print('Description: ' + description)
|
||||||
|
print('Tags: ', tags)
|
||||||
|
print('Privacy: ' + privacy)
|
||||||
|
|
||||||
api = YouTubeAPI(getYouTubeAPIKey())
|
api = YouTubeAPI(getYouTubeAPIKey())
|
||||||
title, date, channel, channelId, description, tags, privacy = api.getVideoInfo(sys.argv[1])
|
videos = api.getPlaylistVideos(sys.argv[1])
|
||||||
print('Title: ' + title)
|
|
||||||
print('Date: ' + date)
|
videoInfo = [api.getVideoInfo(video['snippet']['resourceId']['videoId']) for video in videos]
|
||||||
print('Channel: {} ({})'.format(channel, channelId) )
|
filteredVideos = [video for video in videoInfo if getPrivacy(video) == 'unlisted' and getYear(video) <= 2017]
|
||||||
print('Description: ' + description)
|
|
||||||
print('Tags: ', tags)
|
for v in filteredVideos:
|
||||||
print('Privacy: ' + privacy)
|
print(getYear(v))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user