Skip to main content

this is a simple client for youtube data api v3

Project description

A python library which provides metadata of YouTube videos.

https://img.shields.io/pypi/v/pyytdata https://github.com/Agent-Hellboy/YouTubeDataApi_Wrapper/actions/workflows/build.yml/badge.svg 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/pyytdata/badge.svg

Prerequisites

Installation

for stable version
  • pip install pyytdata

for developement

using

Maybe the first step toward moving the package from a Toy package to a usable package.

An API which will take the URL of youtube video and provide metadata of the video and the channel which has uploaded that video .

>>> from pyytdata import vid_info
>>> l=vid_info('https://www.youtube.com/watch?v=0fqHuIqkOak')
>>> l.get_title()
'Manoj Bajpayee Vs. Atul Khatri | Epic Middle class Face-off | The Family Man | Amazon Prime Video'
l is a VidInfo object
 >>> from 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 date at which the video is published
 >>> vid[0].get_publisheddate()

 # 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'

 # To get the obejct having stat of the video
 >>> vidinf=vid[0].video_stat()

 # To get total number of like to the video
 >>> vidinf.total_like()
 '7203'

 # To get total number of dislike to the video
 >>> vidinf.total_dislike()
 '166'

 # To get total number of views
 >>> vidinf.total_view()
 '436803'

 # To get total number of comment on the video
 >>> vidinf.total_comment()
 '621'

 # To get the object having info about comment on the video
 >>> cmntinfo=vid[0].comment_info()

 >>> cmntinfo.comment_author(2)
 'Fourierwave'

 #To get total number of comment on the video
 >>> cmntinfo.total_comment()
 20

 # To get the info of channel of the author

 >>> cmntinfo.comment_author_channel_info(2)
 # working on it  @ToDo

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 from 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 exists without a channel

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.2.5.tar.gz (8.7 kB view hashes)

Uploaded Source

Built Distribution

pyytdata-0.2.5-py3-none-any.whl (8.7 kB view hashes)

Uploaded Python 3

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