This part will be about the command line options in youtube-dl. We will also inspect how some of them are implemented.
We will go over some of the basic options and a few of the more exotic options. It is good to know how your command-line arguments are being processed in an application.
First of all, the most important option (well, more of a feature than an option) is the URL that you give it at the end. From this URL, youtube-dl has to figure out from which site it comes from, and what kind of resource it points to, as in whether this is a link to a video, playlist, search result, profile or something else.
Despite it's name, it's a generic class that contains the values of the options in a condensed form, and has high-level classes for downloading URLs without having any website-specific code in it. The dirty work of doing the downloading is done by the extractors of each site.
When you run youtube-dl, it first initializes a
YoutubeDL class, and then calls it's
download() method with the list of URLs provided. At that point, youtube-dl checks the URL against the list of extractors it has to see if there is an extractor for it. If no such extractor exists for a URL, it is skipped.
YoutubeDL.download() on Github
With that out of the way, we now turn our attention to the
Here I will cover some of those command-line options that correspond to
YoutubeDL the parameters dictionary
params. They are not keyword arguments (
**kwargs). The names below references the class parameters and may not have the same names as the corresponding command-line options.
simulate: These all do what their corresponding command-line arguments imply.
This is the username and password to login to the website if necessary.
Some sites require a password to access a video, such as if it's password-protected.
Defines the starting and ending index of the playlist. Downloads all the videos between the indices.
playlist_items to download specific indices of videos from the playlist.
Download videos in a playlist in reverse or random order.
Filter videos based on titles or view numbers.
The first parameter is responsible for downloading the video format you specify. The second one prints detailed information about the valid format numbers along with their resolution sizes and file extensions, then quits.
youtube-dl saves the login information and the rest of the cookie data that Youtube (or any other site) sets, into a file provided by this parameter. When the program starts, it also loads cookie data from this file as well.
The first parameter is the URL of your proxy server that you will use to download videos. The second parameter is a proxy that will be used only to fake a geolocation check.
There are more parameters that I haven't covered and I couldn't write about all of them without sounding monotonic. But hopefully you get the general idea of the YoutubeDL constructor, whose source code is located here and here.