this is a simple client for youtube data api v3
Project description
A python library which provides metadata of YouTube videos.
Prerequisites
Get the youtube data v3 api key from https://console.developers.google.com/apis/
Set environment variable API_KEY=’Your YoutubeDatav3 API key’
Installation
- for stable version
pip install pyytdata
- for developement
git clone https://github.com/Agent-Hellboy/YouTubeDataApi_Wrapper/
cd YouTubeDataApi_Wrapper
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
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
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.