Skip to main content

this is a simple client for youtube data api v3

Project description

This is a youtube data api v3 wrapper which can be integrated into any python app basically in the web app which recommends youtube videos.

https://img.shields.io/pypi/v/pyytdata https://travis-ci.org/Agent-Hellboy/YouTubeDataApi_Wrapper.svg?branch=master https://img.shields.io/pypi/pyversions/pyytdata.svg https://img.shields.io/pypi/l/pyytdata.svg https://pepy.tech/badge/pyytdata https://img.shields.io/pypi/format/pyytdata.svg https://coveralls.io/repos/github/Agent-Hellboy/YouTubeDataApi_Wrapper/badge.svg?branch=master

Prerequisites

Installation

for stable version
  • pip install pyytdata

for developement

using

 >>> from pyytdata.pyytdata import PyYtData
 >>> obj=PyYtData('flask',1)
 >>> vid=obj.get_videoinfo()
 >>> vid
 [<util.vidinfo.VidInfo object at 0x7ff971539e10>]


 #You can fire dir on this object to get the attribute and method of the object.
 >>> dir(vid[0])
 ['_Info__API_KEY', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_id', 'channel_info', 'get_description', 'get_image_url', 'get_link', 'get_publishedtime', 'get_title', 'keyword', 'maxlen', 'open_id', 'order', 'result', 'type', 'youtube']

 # To get the description of the video
 >>> vid[0].get_description()
 'Flask is a micro web framework written in Python. It is classified as a microframework because it does not require particular tools or libraries. Learn how to use it ...'

 # To get the title of the video.
 >>> vid[0].get_title()
'Learn Flask for Python - Full Tutorial'

 # To get the link for the video which can we used in web app to open the link for the video.
 >>> vid[0].get_link()
'https://www.youtube.com/watch?v=Z1RJmh_OqeA'

 # To get the title img of the video which can be rendered through HTML tag.
 >>> vid[0].get_image_url()
'https://i.ytimg.com/vi/Z1RJmh_OqeA/mqdefault.jpg'

 # To get the chnlInfo object having methods which describes a channel.
 >>> chnl=vid[0].channel_info()

 >>> dir(chnl)
 ['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__',          '__ge__', '__getattribute__', '__gt__', '__hash__',  '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'id', 'result', 'total_subscriber', 'total_video', 'total_viewcnt', 'youtube']

 # To get the total view count of the channel.
 >>> chnl.total_viewcnt()
 '95246354'

 # To get the number of subscribers of the channel.
 >>> chnl.total_subscriber()
 '2170000'

 # To get number of video uploaded by this particular channel.
 >>> chnl.total_video()
 '1133'

General Info

Under Developement

/images/info.png
  • I think the package has implemented the facade pattern as the lower level packages like videoinfo and chnlinfo are independent form pyytdata and is not exposed to client and also the interaction between querier and videoinfo is hidden from client by providing a interface/module pyytdata

  • vidoinfo class and Chnlinfo has composition relationship as video does not exixts without a channel

Package Architecture

Architecture

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

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

pyytdata-0.1.9.1.tar.gz (3.7 kB view hashes)

Uploaded Source

Supported by

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