2022-05-19 19:45:21 +05:30
import collections
import contextlib
2014-09-13 07:55:21 +02:00
import optparse
2022-04-12 04:02:57 +05:30
import os . path
2016-08-02 17:03:26 +02:00
import re
2022-04-12 01:39:26 +05:30
import shlex
2022-06-24 13:40:17 +05:30
import shutil
2022-05-19 19:45:21 +05:30
import string
2014-09-13 07:55:21 +02:00
import sys
2022-06-24 13:40:17 +05:30
from . compat import compat_expanduser
2021-12-27 01:28:44 +00:00
from . cookies import SUPPORTED_BROWSERS , SUPPORTED_KEYRINGS
2021-05-22 13:54:12 +05:30
from . downloader . external import list_external_downloaders
2023-01-07 08:19:13 +01:00
from . postprocessor . ffmpeg import (
2021-05-22 13:54:12 +05:30
FFmpegExtractAudioPP ,
2022-07-31 01:35:56 +05:30
FFmpegMergerPP ,
2021-05-22 13:54:12 +05:30
FFmpegSubtitlesConvertorPP ,
FFmpegThumbnailsConvertorPP ,
FFmpegVideoRemuxerPP ,
)
2021-09-01 20:55:16 +00:00
from . postprocessor . modify_chapters import DEFAULT_SPONSORBLOCK_CHAPTER_TITLE
2023-01-07 08:19:13 +01:00
from . postprocessor . sponsorblock import SponsorBlockPP
2023-03-03 22:36:11 +05:30
from . update import UPDATE_SOURCES , detect_variant , is_non_updateable
2022-04-12 04:02:57 +05:30
from . utils import (
OUTTMPL_TYPES ,
POSTPROCESS_WHEN ,
Config ,
2022-08-30 20:58:28 +05:30
deprecation_warning ,
2022-04-12 04:02:57 +05:30
expand_path ,
2022-07-29 20:33:01 +05:30
format_field ,
2022-04-12 04:02:57 +05:30
get_executable_path ,
2023-01-01 04:29:22 +00:00
get_system_config_dirs ,
get_user_config_dirs ,
2022-04-18 02:28:28 +05:30
join_nonempty ,
2022-08-24 07:38:55 +05:30
orderedSet_from_options ,
2022-04-12 04:02:57 +05:30
remove_end ,
write_string ,
)
2023-03-03 22:36:11 +05:30
from . version import CHANNEL , __version__
2021-05-22 13:54:12 +05:30
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
def parseOpts ( overrideArguments = None , ignore_config_files = " if_override " ) :
PACKAGE_NAME = " yt-dlp "
2023-01-06 20:01:00 +01:00
2022-05-19 19:45:21 +05:30
root = Config ( create_parser ( ) )
2023-03-18 16:59:11 +01:00
if ignore_config_files == " if_override " :
2021-12-14 22:33:47 +05:30
ignore_config_files = overrideArguments is not None
2014-09-13 07:55:21 +02:00
2023-01-06 20:01:00 +01:00
def read_config ( * paths ) :
path = os . path . join ( * paths )
conf = Config . read_file ( path , default = None )
if conf is not None :
return conf , path
2023-01-01 04:29:22 +00:00
def _load_from_config_dirs ( config_dirs ) :
for config_dir in config_dirs :
2023-01-06 20:01:00 +01:00
head , tail = os . path . split ( config_dir )
2023-03-18 16:59:11 +01:00
assert tail == PACKAGE_NAME or config_dir == os . path . join (
compat_expanduser ( " ~ " ) , f " . { PACKAGE_NAME } "
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
yield read_config ( head , f " { PACKAGE_NAME } .conf " )
if tail . startswith ( " . " ) : # ~/.PACKAGE_NAME
yield read_config ( head , f " { PACKAGE_NAME } .conf.txt " )
yield read_config ( config_dir , " config " )
yield read_config ( config_dir , " config.txt " )
2014-09-13 07:55:21 +02:00
2023-01-01 04:29:22 +00:00
def add_config ( label , path = None , func = None ) :
2023-03-18 16:59:11 +01:00
""" Adds config and returns whether to continue """
2022-05-19 19:45:21 +05:30
if root . parse_known_args ( ) [ 0 ] . ignoreconfig :
2021-12-14 22:33:47 +05:30
return False
2023-01-01 04:29:22 +00:00
elif func :
assert path is None
2023-01-06 20:01:00 +01:00
args , current_path = next (
2023-03-18 16:59:11 +01:00
filter ( None , _load_from_config_dirs ( func ( PACKAGE_NAME ) ) ) , ( None , None )
)
2023-01-01 04:29:22 +00:00
else :
2023-03-18 16:59:11 +01:00
current_path = os . path . join ( path , " yt-dlp.conf " )
2023-01-01 04:29:22 +00:00
args = Config . read_file ( current_path , default = None )
if args is not None :
root . append_config ( args , current_path , label = label )
2021-12-14 22:33:47 +05:30
return True
def load_configs ( ) :
yield not ignore_config_files
2023-03-18 16:59:11 +01:00
yield add_config ( " Portable " , get_executable_path ( ) )
yield add_config (
" Home " ,
expand_path ( root . parse_known_args ( ) [ 0 ] . paths . get ( " home " , " " ) ) . strip ( ) ,
)
yield add_config ( " User " , func = get_user_config_dirs )
yield add_config ( " System " , func = get_system_config_dirs )
2021-12-14 22:33:47 +05:30
2023-03-18 16:59:11 +01:00
opts = optparse . Values ( { " verbose " : True , " print_help " : False } )
2022-05-19 19:45:21 +05:30
try :
2022-06-18 09:17:45 +05:30
try :
2023-01-02 19:39:03 +05:30
if overrideArguments is not None :
2023-03-18 16:59:11 +01:00
root . append_config ( overrideArguments , label = " Override " )
2022-06-18 09:17:45 +05:30
else :
2023-03-18 16:59:11 +01:00
root . append_config ( sys . argv [ 1 : ] , label = " Command-line " )
2022-06-18 09:17:45 +05:30
loaded_all_configs = all ( load_configs ( ) )
except ValueError as err :
raise root . parser . error ( err )
2022-05-19 19:45:21 +05:30
2022-06-18 09:17:45 +05:30
if loaded_all_configs :
2022-05-19 19:45:21 +05:30
# If ignoreconfig is found inside the system configuration file,
# the user configuration is removed
if root . parse_known_args ( ) [ 0 ] . ignoreconfig :
2023-03-18 16:59:11 +01:00
user_conf = next (
( i for i , conf in enumerate ( root . configs ) if conf . label == " User " ) ,
None ,
)
2022-05-19 19:45:21 +05:30
if user_conf is not None :
root . configs . pop ( user_conf )
2021-12-14 22:33:47 +05:30
2022-07-01 09:30:21 +05:30
try :
2023-03-18 16:59:11 +01:00
root . configs [
0
] . load_configs ( ) # Resolve any aliases using --config-location
2022-07-01 09:30:21 +05:30
except ValueError as err :
raise root . parser . error ( err )
2022-05-19 19:45:21 +05:30
opts , args = root . parse_args ( )
except optparse . OptParseError :
with contextlib . suppress ( optparse . OptParseError ) :
opts , _ = root . parse_known_args ( strict = False )
raise
except ( SystemExit , KeyboardInterrupt ) :
opts . verbose = False
raise
finally :
2023-03-18 16:59:11 +01:00
verbose = opts . verbose and f " \n { root } " . replace ( " \n | " , " \n [debug] " ) [ 1 : ]
2022-05-19 19:45:21 +05:30
if verbose :
2023-03-18 16:59:11 +01:00
write_string ( f " { verbose } \n " )
2022-05-19 19:45:21 +05:30
if opts . print_help :
if verbose :
2023-03-18 16:59:11 +01:00
write_string ( " \n " )
2022-05-19 19:45:21 +05:30
root . parser . print_help ( )
if opts . print_help :
sys . exit ( )
return root . parser , opts , args
2021-12-14 22:33:47 +05:30
2022-04-18 02:28:28 +05:30
class _YoutubeDLHelpFormatter ( optparse . IndentedHelpFormatter ) :
def __init__ ( self ) :
# No need to wrap help messages if we're on a wide console
2022-06-24 13:40:17 +05:30
max_width = shutil . get_terminal_size ( ) . columns or 80
2022-05-19 20:05:17 +05:30
# The % is chosen to get a pretty output in README.md
super ( ) . __init__ ( width = max_width , max_help_position = int ( 0.45 * max_width ) )
2022-04-18 02:28:28 +05:30
@staticmethod
def format_option_strings ( option ) :
2023-03-18 16:59:11 +01:00
""" ( ' -o ' , ' --option ' ) -> -o, --format METAVAR """
2022-04-18 02:28:28 +05:30
opts = join_nonempty (
option . _short_opts and option . _short_opts [ 0 ] ,
option . _long_opts and option . _long_opts [ 0 ] ,
2023-03-18 16:59:11 +01:00
delim = " , " ,
)
2022-04-18 02:28:28 +05:30
if option . takes_value ( ) :
2023-03-18 16:59:11 +01:00
opts + = f " { option . metavar } "
2022-04-18 02:28:28 +05:30
return opts
2022-02-10 21:07:08 +05:30
class _YoutubeDLOptionParser ( optparse . OptionParser ) :
# optparse is deprecated since python 3.2. So assume a stable interface even for private methods
2023-03-18 16:59:11 +01:00
ALIAS_DEST = " _triggered_aliases "
2022-05-19 19:45:21 +05:30
ALIAS_TRIGGER_LIMIT = 100
2022-02-10 21:07:08 +05:30
2022-04-18 02:28:28 +05:30
def __init__ ( self ) :
super ( ) . __init__ (
2023-03-18 16:59:11 +01:00
prog = " yt-dlp " if detect_variant ( ) == " source " else None ,
2022-04-18 02:28:28 +05:30
version = __version__ ,
2023-03-18 16:59:11 +01:00
usage = " % prog [OPTIONS] URL [URL...] " ,
epilog = " See full documentation at https://github.com/yt-dlp/yt-dlp#readme " ,
2022-04-18 02:28:28 +05:30
formatter = _YoutubeDLHelpFormatter ( ) ,
2023-03-18 16:59:11 +01:00
conflict_handler = " resolve " ,
2022-04-18 02:28:28 +05:30
)
2022-08-26 06:07:47 +05:30
self . set_default ( self . ALIAS_DEST , collections . defaultdict ( int ) )
2022-04-18 02:28:28 +05:30
2022-05-19 19:45:21 +05:30
_UNKNOWN_OPTION = ( optparse . BadOptionError , optparse . AmbiguousOptionError )
_BAD_OPTION = optparse . OptionValueError
def parse_known_args ( self , args = None , values = None , strict = True ) :
""" Same as parse_args, but ignore unknown switches. Similar to argparse.parse_known_args """
self . rargs , self . largs = self . _get_args ( args ) , [ ]
self . values = values or self . get_default_values ( )
while self . rargs :
2022-06-25 08:38:52 +05:30
arg = self . rargs [ 0 ]
2022-05-19 19:45:21 +05:30
try :
2023-03-18 16:59:11 +01:00
if arg == " -- " :
2022-06-25 08:38:52 +05:30
del self . rargs [ 0 ]
break
2023-03-18 16:59:11 +01:00
elif arg . startswith ( " -- " ) :
2022-06-25 08:38:52 +05:30
self . _process_long_opt ( self . rargs , self . values )
2023-03-18 16:59:11 +01:00
elif arg . startswith ( " - " ) and arg != " - " :
2022-06-25 08:38:52 +05:30
self . _process_short_opts ( self . rargs , self . values )
elif self . allow_interspersed_args :
self . largs . append ( self . rargs . pop ( 0 ) )
else :
break
2022-05-19 19:45:21 +05:30
except optparse . OptParseError as err :
if isinstance ( err , self . _UNKNOWN_OPTION ) :
self . largs . append ( err . opt_str )
elif strict :
if isinstance ( err , self . _BAD_OPTION ) :
self . error ( str ( err ) )
raise
return self . check_values ( self . values , self . largs )
def error ( self , msg ) :
2023-03-18 16:59:11 +01:00
msg = f " { self . get_prog_name ( ) } : error: { str ( msg ) . strip ( ) } \n "
raise optparse . OptParseError (
f " { self . get_usage ( ) } \n { msg } " if self . usage else msg
)
2022-05-19 19:45:21 +05:30
2022-04-18 02:28:28 +05:30
def _get_args ( self , args ) :
return sys . argv [ 1 : ] if args is None else list ( args )
2022-02-10 21:07:08 +05:30
def _match_long_opt ( self , opt ) :
2022-06-26 20:50:06 -04:00
""" Improve ambiguous argument resolution by comparing option objects instead of argument strings """
2022-02-10 21:07:08 +05:30
try :
return super ( ) . _match_long_opt ( opt )
except optparse . AmbiguousOptionError as e :
2022-04-11 20:40:28 +05:30
if len ( { self . _long_opt [ p ] for p in e . possibilities } ) == 1 :
2022-02-10 21:07:08 +05:30
return e . possibilities [ 0 ]
raise
2021-12-14 22:33:47 +05:30
def create_parser ( ) :
2023-03-18 16:59:11 +01:00
def _list_from_options_callback (
option , opt_str , value , parser , append = True , delim = " , " , process = str . strip
) :
2021-05-13 17:51:22 +05:30
# append can be True, False or -1 (prepend)
2022-01-04 01:07:24 +05:30
current = list ( getattr ( parser . values , option . dest ) ) if append else [ ]
2023-03-18 16:59:11 +01:00
value = list (
filter (
None ,
[ process ( value ) ] if delim is None else map ( process , value . split ( delim ) ) ,
)
)
Improve argument parsing for `-P`, `-o`, `-S`
* `-P "subtitle,thumbnail:PATH"` is now possible. Similarly for `-o`
* `-S "fps,br" -S "res,codec"` is now interpreted as `-S res,codec,fps,br`. Previously, `-S fps,br` was ignored in this case.
2021-04-10 20:30:38 +05:30
setattr (
2023-03-18 16:59:11 +01:00
parser . values ,
option . dest ,
current + value if append is True else value + current ,
)
2014-09-13 07:55:21 +02:00
2021-08-15 00:24:53 +05:30
def _set_from_options_callback (
2023-03-18 16:59:11 +01:00
option ,
opt_str ,
value ,
parser ,
allowed_values ,
delim = " , " ,
aliases = { } ,
process = lambda x : x . lower ( ) . strip ( ) ,
) :
2022-08-24 07:38:55 +05:30
values = [ process ( value ) ] if delim is None else map ( process , value . split ( delim ) )
try :
2023-03-18 16:59:11 +01:00
requested = orderedSet_from_options (
values ,
collections . ChainMap ( aliases , { " all " : allowed_values } ) ,
start = getattr ( parser . values , option . dest ) ,
)
2022-08-24 07:38:55 +05:30
except ValueError as e :
2023-03-18 16:59:11 +01:00
raise optparse . OptionValueError (
f " wrong { option . metavar } for { opt_str } : { e . args [ 0 ] } "
)
2021-08-15 00:24:53 +05:30
2022-08-24 07:38:55 +05:30
setattr ( parser . values , option . dest , set ( requested ) )
2021-08-15 00:24:53 +05:30
2021-05-13 17:51:22 +05:30
def _dict_from_options_callback (
2023-03-18 16:59:11 +01:00
option ,
opt_str ,
value ,
parser ,
allowed_keys = r " [ \ w-]+ " ,
delimiter = " : " ,
default_key = None ,
process = None ,
multiple_keys = True ,
process_key = str . lower ,
append = False ,
) :
2021-01-23 11:27:27 +05:30
2022-01-02 16:22:00 +05:30
out_dict = dict ( getattr ( parser . values , option . dest ) )
2022-01-24 03:04:19 +05:30
multiple_args = not isinstance ( value , str )
Improve argument parsing for `-P`, `-o`, `-S`
* `-P "subtitle,thumbnail:PATH"` is now possible. Similarly for `-o`
* `-S "fps,br" -S "res,codec"` is now interpreted as `-S res,codec,fps,br`. Previously, `-S fps,br` was ignored in this case.
2021-04-10 20:30:38 +05:30
if multiple_keys :
2023-03-18 16:59:11 +01:00
allowed_keys = rf " ( { allowed_keys } )(,( { allowed_keys } ))* "
2022-01-24 03:04:19 +05:30
mobj = re . match (
2023-03-18 16:59:11 +01:00
rf " (?i)(?P<keys> { allowed_keys } ) { delimiter } (?P<val>.*)$ " ,
value [ 0 ] if multiple_args else value ,
)
2021-01-23 11:27:27 +05:30
if mobj is not None :
2023-03-18 16:59:11 +01:00
keys , val = mobj . group ( " keys " ) . split ( " , " ) , mobj . group ( " val " )
2022-01-24 03:04:19 +05:30
if multiple_args :
val = [ val , * value [ 1 : ] ]
2021-01-23 11:27:27 +05:30
elif default_key is not None :
Improve argument parsing for `-P`, `-o`, `-S`
* `-P "subtitle,thumbnail:PATH"` is now possible. Similarly for `-o`
* `-S "fps,br" -S "res,codec"` is now interpreted as `-S res,codec,fps,br`. Previously, `-S fps,br` was ignored in this case.
2021-04-10 20:30:38 +05:30
keys , val = [ default_key ] , value
2021-01-23 11:27:27 +05:30
else :
raise optparse . OptionValueError (
2023-03-18 16:59:11 +01:00
f ' wrong { opt_str } formatting; it should be { option . metavar } , not " { value } " '
)
2021-07-08 21:03:13 +05:30
try :
2021-11-10 18:33:37 +05:30
keys = map ( process_key , keys ) if process_key else keys
2021-07-08 21:03:13 +05:30
val = process ( val ) if process else val
except Exception as err :
2023-03-18 16:59:11 +01:00
raise optparse . OptionValueError ( f " wrong { opt_str } formatting; { err } " )
Improve argument parsing for `-P`, `-o`, `-S`
* `-P "subtitle,thumbnail:PATH"` is now possible. Similarly for `-o`
* `-S "fps,br" -S "res,codec"` is now interpreted as `-S res,codec,fps,br`. Previously, `-S fps,br` was ignored in this case.
2021-04-10 20:30:38 +05:30
for key in keys :
2022-01-02 16:22:00 +05:30
out_dict [ key ] = out_dict . get ( key , [ ] ) + [ val ] if append else val
setattr ( parser . values , option . dest , out_dict )
2021-01-23 11:27:27 +05:30
2022-12-30 11:15:41 +05:30
def when_prefix ( default ) :
return {
2023-03-18 16:59:11 +01:00
" default " : { } ,
" type " : " str " ,
" action " : " callback " ,
" callback " : _dict_from_options_callback ,
" callback_kwargs " : {
" allowed_keys " : " | " . join ( map ( re . escape , POSTPROCESS_WHEN ) ) ,
" default_key " : default ,
" multiple_keys " : False ,
" append " : True ,
2022-12-30 11:15:41 +05:30
} ,
}
2022-04-18 02:28:28 +05:30
parser = _YoutubeDLOptionParser ( )
2023-03-18 16:59:11 +01:00
alias_group = optparse . OptionGroup ( parser , " Aliases " )
2022-05-19 19:45:21 +05:30
Formatter = string . Formatter ( )
def _create_alias ( option , opt_str , value , parser ) :
aliases , opts = value
try :
2023-03-18 16:59:11 +01:00
nargs = len (
{
i if f == " " else f
for i , ( _ , f , _ , _ ) in enumerate ( Formatter . parse ( opts ) )
if f is not None
}
)
2022-05-19 19:45:21 +05:30
opts . format ( * map ( str , range ( nargs ) ) ) # validate
except Exception as err :
2023-03-18 16:59:11 +01:00
raise optparse . OptionValueError (
f " wrong { opt_str } OPTIONS formatting; { err } "
)
2022-05-19 19:45:21 +05:30
if alias_group not in parser . option_groups :
parser . add_option_group ( alias_group )
2023-03-18 16:59:11 +01:00
aliases = (
x if x . startswith ( " - " ) else f " -- { x } "
for x in map ( str . strip , aliases . split ( " , " ) )
)
2022-05-19 19:45:21 +05:30
try :
2023-03-18 16:59:11 +01:00
args = [ f " ARG { i } " for i in range ( nargs ) ]
2022-05-19 19:45:21 +05:30
alias_group . add_option (
2023-03-18 16:59:11 +01:00
* aliases ,
nargs = nargs ,
dest = parser . ALIAS_DEST ,
type = " str " if nargs else None ,
metavar = " " . join ( args ) ,
help = opts . format ( * args ) ,
action = " callback " ,
callback = _alias_callback ,
callback_kwargs = { " opts " : opts , " nargs " : nargs } ,
)
2022-05-19 19:45:21 +05:30
except Exception as err :
2023-03-18 16:59:11 +01:00
raise optparse . OptionValueError ( f " wrong { opt_str } formatting; { err } " )
2022-05-19 19:45:21 +05:30
def _alias_callback ( option , opt_str , value , parser , opts , nargs ) :
counter = getattr ( parser . values , option . dest )
counter [ opt_str ] + = 1
if counter [ opt_str ] > parser . ALIAS_TRIGGER_LIMIT :
2023-03-18 16:59:11 +01:00
raise optparse . OptionValueError (
f " Alias { opt_str } exceeded invocation limit "
)
2022-05-19 19:45:21 +05:30
if nargs == 1 :
value = [ value ]
assert ( nargs == 0 and value is None ) or len ( value ) == nargs
parser . rargs [ : 0 ] = shlex . split (
2023-03-18 16:59:11 +01:00
opts if value is None else opts . format ( * map ( shlex . quote , value ) )
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
general = optparse . OptionGroup ( parser , " General Options " )
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" -h " ,
" --help " ,
dest = " print_help " ,
action = " store_true " ,
help = " Print this help text and exit " ,
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --version " , action = " version " , help = " Print program version and exit "
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" -U " ,
" --update " ,
action = " store_true " ,
dest = " update_self " ,
2022-07-29 20:33:01 +05:30
help = format_field (
2023-03-18 16:59:11 +01:00
is_non_updateable ( ) ,
None ,
" Check if updates are available. %s " ,
default = f " Update this program to the latest { CHANNEL } version " ,
) ,
)
2022-06-13 19:15:54 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-update " ,
action = " store_false " ,
dest = " update_self " ,
help = " Do not check for updates (default) " ,
)
2022-06-13 19:15:54 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --update-to " ,
action = " store " ,
dest = " update_self " ,
metavar = " [CHANNEL]@[TAG] " ,
2023-03-03 22:36:11 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Upgrade/downgrade to a specific version. CHANNEL and TAG defaults to "
2023-03-03 22:40:16 +05:30
f ' " { CHANNEL } " and " latest " respectively if omitted; See " UPDATE " for details. '
2023-03-18 16:59:11 +01:00
f ' Supported channels: { " , " . join ( UPDATE_SOURCES ) } '
) ,
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" -i " ,
" --ignore-errors " ,
action = " store_true " ,
dest = " ignoreerrors " ,
help = " Ignore download and postprocessing errors. The download will be considered successful even if the postprocessing fails " ,
)
2021-09-24 05:51:54 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-abort-on-error " ,
action = " store_const " ,
dest = " ignoreerrors " ,
const = " only_download " ,
help = " Continue with next video on download errors; e.g. to skip unavailable videos in a playlist (default) " ,
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --abort-on-error " ,
" --no-ignore-errors " ,
action = " store_false " ,
dest = " ignoreerrors " ,
help = " Abort downloading of further videos if an error occurs (Alias: --no-ignore-errors) " ,
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --dump-user-agent " ,
action = " store_true " ,
dest = " dump_user_agent " ,
default = False ,
help = " Display the current user-agent and exit " ,
)
2014-09-13 07:55:21 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --list-extractors " ,
action = " store_true " ,
dest = " list_extractors " ,
default = False ,
help = " List all supported extractors and exit " ,
)
2014-10-12 23:10:11 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --extractor-descriptions " ,
action = " store_true " ,
dest = " list_extractor_descriptions " ,
default = False ,
help = " Output descriptions of all supported extractors and exit " ,
)
2022-08-24 05:42:16 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --use-extractors " ,
" --ies " ,
action = " callback " ,
dest = " allowed_extractors " ,
metavar = " NAMES " ,
type = " str " ,
default = [ ] ,
callback = _list_from_options_callback ,
2022-08-24 05:42:16 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Extractor names to use separated by commas. "
2022-08-24 05:42:16 +05:30
' You can also use regexes, " all " , " default " and " end " (end URL matching); '
' e.g. --ies " holodex.*,end,youtube " . '
' Prefix the name with a " - " to exclude it, e.g. --ies default,-generic. '
2023-03-18 16:59:11 +01:00
" Use --list-extractors for a list of extractor names. (Alias: --ies) "
) ,
)
2015-06-12 19:20:12 +06:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --force-generic-extractor " ,
action = " store_true " ,
dest = " force_generic_extractor " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-09-13 07:55:21 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --default-search " ,
dest = " default_search " ,
metavar = " PREFIX " ,
2022-05-19 20:05:17 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Use this prefix for unqualified URLs. "
2022-08-14 21:04:13 +09:00
' E.g. " gvsearch2:python " downloads two videos from google videos for the search term " python " . '
2022-05-19 20:05:17 +05:30
' Use the value " auto " to let yt-dlp guess ( " auto_warning " to emit a warning when guessing). '
' " error " just throws an error. The default value " fixup_error " repairs broken URLs, '
2023-03-18 16:59:11 +01:00
" but emits an error if this is not possible instead of searching "
) ,
)
2014-09-13 07:55:21 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --ignore-config " ,
" --no-config " ,
action = " store_true " ,
dest = " ignoreconfig " ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Don ' t load any more configuration files except those given by --config-locations. "
" For backward compatibility, if this option is found inside the system configuration file, the user configuration is not loaded. "
" (Alias: --no-config) "
) ,
)
2016-09-14 17:28:17 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-config-locations " ,
action = " store_const " ,
dest = " config_locations " ,
const = [ ] ,
2021-12-14 22:33:47 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Do not load any custom configuration files (default). When given inside a "
" configuration file, ignore all previous --config-locations defined in the current file "
) ,
)
2021-12-14 22:33:47 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --config-locations " ,
dest = " config_locations " ,
metavar = " PATH " ,
action = " append " ,
2021-12-14 22:33:47 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Location of the main configuration file; either the path to the config or its containing directory "
' ( " - " for stdin). Can be used multiple times and inside other configuration files '
) ,
)
2014-10-24 14:48:12 +02:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --flat-playlist " ,
action = " store_const " ,
dest = " extract_flat " ,
const = " in_playlist " ,
default = False ,
help = " Do not extract the videos of a playlist, only list them " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-flat-playlist " ,
action = " store_false " ,
dest = " extract_flat " ,
help = " Extract the videos of a playlist " ,
)
2021-12-20 15:06:46 +09:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --live-from-start " ,
action = " store_true " ,
dest = " live_from_start " ,
help = " Download livestreams from the start. Currently only supported for YouTube (Experimental) " ,
)
2021-12-20 15:06:46 +09:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-live-from-start " ,
action = " store_false " ,
dest = " live_from_start " ,
help = " Download livestreams from the current time (default) " ,
)
2021-11-29 00:27:44 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --wait-for-video " ,
dest = " wait_for_video " ,
metavar = " MIN[-MAX] " ,
default = None ,
2021-11-29 00:27:44 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Wait for scheduled streams to become available. "
" Pass the minimum number of seconds (or range) to wait between retries "
) ,
)
2021-11-29 00:27:44 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-wait-for-video " ,
dest = " wait_for_video " ,
action = " store_const " ,
const = None ,
help = " Do not wait for scheduled streams (default) " ,
)
2016-03-01 01:01:33 +06:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --mark-watched " ,
action = " store_true " ,
dest = " mark_watched " ,
default = False ,
help = " Mark videos watched (even with --simulate) " ,
)
2016-03-01 23:41:23 +06:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-mark-watched " ,
action = " store_false " ,
dest = " mark_watched " ,
help = " Do not mark videos watched (default) " ,
)
2015-02-10 04:22:10 +01:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --no-colors " ,
" --no-colours " ,
action = " store_true " ,
dest = " no_color " ,
default = False ,
help = " Do not emit color codes in output (Alias: --no-colours) " ,
)
2023-01-07 08:19:13 +01:00
general . add_option (
2023-03-18 16:59:11 +01:00
" --plugin-dirs " ,
metavar = " PATH " ,
dest = " plugin_dirs " ,
action = " append " ,
2023-01-07 08:19:13 +01:00
help = (
2023-03-18 16:59:11 +01:00
" Directory to search for plugins. Can be used multiple times to add multiple directories. "
' Add " no-default " to disable the default plugin directories '
) ,
)
2021-05-11 13:30:48 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --compat-options " ,
metavar = " OPTS " ,
dest = " compat_opts " ,
default = set ( ) ,
type = " str " ,
action = " callback " ,
callback = _set_from_options_callback ,
2021-08-15 00:24:53 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_values " : {
" filename " ,
" filename-sanitization " ,
" format-sort " ,
" abort-on-error " ,
" format-spec " ,
" no-playlist-metafiles " ,
" multistreams " ,
" no-live-chat " ,
" playlist-index " ,
" list-formats " ,
" no-direct-merge " ,
" no-attach-info-json " ,
" embed-thumbnail-atomicparsley " ,
" no-external-downloader-progress " ,
" embed-metadata " ,
" seperate-video-versions " ,
" no-clean-infojson " ,
" no-keep-subs " ,
" no-certifi " ,
" no-youtube-channel-redirect " ,
" no-youtube-unavailable-videos " ,
" no-youtube-prefer-utc-upload-date " ,
} ,
" aliases " : {
" youtube-dl " : [ " all " , " -multistreams " ] ,
" youtube-dlc " : [ " all " , " -no-youtube-channel-redirect " , " -no-live-chat " ] ,
" 2021 " : [
" 2022 " ,
" no-certifi " ,
" filename-sanitization " ,
" no-youtube-prefer-utc-upload-date " ,
] ,
" 2022 " : [ " no-external-downloader-progress " ] ,
} ,
} ,
help = (
" Options that can help keep compatibility with youtube-dl or youtube-dlc "
" configurations by reverting some of the changes made in yt-dlp. "
' See " Differences in default behavior " for details '
) ,
)
2022-05-19 19:45:21 +05:30
general . add_option (
2023-03-18 16:59:11 +01:00
" --alias " ,
metavar = " ALIASES OPTIONS " ,
dest = " _ " ,
type = " str " ,
nargs = 2 ,
action = " callback " ,
callback = _create_alias ,
2022-05-19 19:45:21 +05:30
help = (
' Create aliases for an option string. Unless an alias starts with a dash " - " , it is prefixed with " -- " . '
2023-03-18 16:59:11 +01:00
" Arguments are parsed according to the Python string formatting mini-language. "
2022-08-14 21:04:13 +09:00
' E.g. --alias get-audio,-X " -S=aext: {0} ,abr -x --audio-format {0} " creates options '
2022-05-19 19:45:21 +05:30
' " --get-audio " and " -X " that takes an argument (ARG0) and expands to '
' " -S=aext:ARG0,abr -x --audio-format ARG0 " . All defined aliases are listed in the --help output. '
2023-03-18 16:59:11 +01:00
" Alias options can trigger more aliases; so be careful to avoid defining recursive options. "
f " As a safety measure, each alias may be triggered a maximum of { _YoutubeDLOptionParser . ALIAS_TRIGGER_LIMIT } times. "
" This option can be used multiple times "
) ,
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
network = optparse . OptionGroup ( parser , " Network Options " )
2015-01-10 19:55:36 +01:00
network . add_option (
2023-03-18 16:59:11 +01:00
" --proxy " ,
dest = " proxy " ,
default = None ,
metavar = " URL " ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Use the specified HTTP/HTTPS/SOCKS proxy. To enable SOCKS proxy, specify a proper scheme, "
' e.g. socks5://user:pass@127.0.0.1:1080/. Pass in an empty string (--proxy " " ) for direct connection '
) ,
)
2015-01-10 19:55:36 +01:00
network . add_option (
2023-03-18 16:59:11 +01:00
" --socket-timeout " ,
dest = " socket_timeout " ,
type = float ,
default = None ,
metavar = " SECONDS " ,
help = " Time to wait before giving up, in seconds " ,
)
2015-01-10 19:55:36 +01:00
network . add_option (
2023-03-18 16:59:11 +01:00
" --source-address " ,
metavar = " IP " ,
dest = " source_address " ,
default = None ,
help = " Client-side IP address to bind to " ,
2015-01-10 19:55:36 +01:00
)
2015-01-10 20:02:02 +01:00
network . add_option (
2023-03-18 16:59:11 +01:00
" -4 " ,
" --force-ipv4 " ,
action = " store_const " ,
const = " 0.0.0.0 " ,
dest = " source_address " ,
help = " Make all connections via IPv4 " ,
2015-01-10 20:02:02 +01:00
)
network . add_option (
2023-03-18 16:59:11 +01:00
" -6 " ,
" --force-ipv6 " ,
action = " store_const " ,
const = " :: " ,
dest = " source_address " ,
help = " Make all connections via IPv6 " ,
2015-01-10 20:02:02 +01:00
)
2023-01-02 06:05:13 +00:00
network . add_option (
2023-03-18 16:59:11 +01:00
" --enable-file-urls " ,
action = " store_true " ,
dest = " enable_file_urls " ,
default = False ,
help = " Enable file:// URLs. This is disabled by default for security reasons. " ,
2023-01-02 06:05:13 +00:00
)
2017-02-19 03:58:17 +07:00
2023-03-18 16:59:11 +01:00
geo = optparse . OptionGroup ( parser , " Geo-restriction " )
2017-02-19 03:58:17 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --geo-verification-proxy " ,
dest = " geo_verification_proxy " ,
default = None ,
metavar = " URL " ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Use this proxy to verify the IP address for some geo-restricted sites. "
" The default proxy specified by --proxy (or none, if the option is not present) is used for the actual downloading "
) ,
)
2017-02-19 03:58:17 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --cn-verification-proxy " ,
dest = " cn_verification_proxy " ,
default = None ,
metavar = " URL " ,
help = optparse . SUPPRESS_HELP ,
)
2017-02-19 03:58:17 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --geo-bypass " ,
action = " store_true " ,
dest = " geo_bypass " ,
default = True ,
help = " Bypass geographic restriction via faking X-Forwarded-For HTTP header (default) " ,
)
2017-02-19 03:58:17 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --no-geo-bypass " ,
action = " store_false " ,
dest = " geo_bypass " ,
help = " Do not bypass geographic restriction via faking X-Forwarded-For HTTP header " ,
)
2017-02-19 03:58:17 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --geo-bypass-country " ,
metavar = " CODE " ,
dest = " geo_bypass_country " ,
default = None ,
help = " Force bypass geographic restriction with explicitly provided two-letter ISO 3166-2 country code " ,
)
2018-05-02 07:18:01 +07:00
geo . add_option (
2023-03-18 16:59:11 +01:00
" --geo-bypass-ip-block " ,
metavar = " IP_BLOCK " ,
dest = " geo_bypass_ip_block " ,
default = None ,
help = " Force bypass geographic restriction with explicitly provided IP block in CIDR notation " ,
)
2015-01-10 19:55:36 +01:00
2023-03-18 16:59:11 +01:00
selection = optparse . OptionGroup ( parser , " Video Selection " )
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --playlist-start " ,
dest = " playliststart " ,
metavar = " NUMBER " ,
default = 1 ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --playlist-end " ,
dest = " playlistend " ,
metavar = " NUMBER " ,
default = None ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2015-01-25 04:24:55 +01:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" -I " ,
" --playlist-items " ,
dest = " playlist_items " ,
metavar = " ITEM_SPEC " ,
default = None ,
2022-06-17 10:18:21 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Comma separated playlist_index of the items to download. "
2022-06-17 10:18:21 +05:30
' You can specify a range using " [START]:[STOP][:STEP] " . For backward compatibility, START-STOP is also supported. '
2023-03-18 16:59:11 +01:00
" Use negative indices to count from the right and negative STEP to download in reverse order. "
' E.g. " -I 1:3,7,-5::2 " used on a playlist of size 15 will download the items at index 1,2,3,7,11,13,15 '
) ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --match-title " , dest = " matchtitle " , metavar = " REGEX " , help = optparse . SUPPRESS_HELP
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --reject-title " ,
dest = " rejecttitle " ,
metavar = " REGEX " ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --min-filesize " ,
metavar = " SIZE " ,
dest = " min_filesize " ,
default = None ,
help = " Abort download if filesize is smaller than SIZE, e.g. 50k or 44.6M " ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --max-filesize " ,
metavar = " SIZE " ,
dest = " max_filesize " ,
default = None ,
help = " Abort download if filesize is larger than SIZE, e.g. 50k or 44.6M " ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --date " ,
metavar = " DATE " ,
dest = " date " ,
default = None ,
2021-01-07 12:11:05 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Download only videos uploaded on this date. "
2023-01-02 19:39:28 +05:30
' The date can be " YYYYMMDD " or in the format [now|today|yesterday][-N[day|week|month|year]]. '
2023-03-18 16:59:11 +01:00
' E.g. " --date today-2weeks " downloads only videos uploaded on the same day two weeks ago '
) ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --datebefore " ,
metavar = " DATE " ,
dest = " datebefore " ,
default = None ,
2021-01-07 12:11:05 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Download only videos uploaded on or before this date. "
" The date formats accepted is the same as --date "
) ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --dateafter " ,
metavar = " DATE " ,
dest = " dateafter " ,
default = None ,
2021-01-07 12:11:05 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Download only videos uploaded on or after this date. "
" The date formats accepted is the same as --date "
) ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --min-views " ,
metavar = " COUNT " ,
dest = " min_views " ,
default = None ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --max-views " ,
metavar = " COUNT " ,
dest = " max_views " ,
default = None ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2015-02-10 03:32:21 +01:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --match-filters " ,
metavar = " FILTER " ,
dest = " match_filter " ,
action = " append " ,
2015-02-10 03:32:21 +01:00
help = (
2022-05-19 20:05:17 +05:30
' Generic video filter. Any " OUTPUT TEMPLATE " field can be compared with a '
2022-08-01 04:05:59 +02:00
' number or a string using the operators defined in " Filtering Formats " . '
2023-03-18 16:59:11 +01:00
" You can also simply specify a field to match if the field is present, "
2022-03-25 13:32:54 +05:30
' use " !field " to check if the field is not present, and " & " to check multiple conditions. '
' Use a " \\ " to escape " & " or quotes if needed. If used multiple times, '
2023-03-18 16:59:11 +01:00
" the filter matches if atleast one of the conditions are met. E.g. --match-filter "
" !is_live --match-filter \" like_count>?100 & description~= ' (?i) \\ bcats \\ & dogs \\ b ' \" "
" matches only videos that are not live OR those that have a like count more than 100 "
" (or the like field is not available) and also has a description "
2022-05-19 20:05:17 +05:30
' that contains the phrase " cats & dogs " (caseless). '
2023-03-18 16:59:11 +01:00
' Use " --match-filter - " to interactively ask whether to download each video '
) ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-match-filter " ,
dest = " match_filter " ,
action = " store_const " ,
const = None ,
help = " Do not use any --match-filter (default) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --break-match-filters " ,
metavar = " FILTER " ,
dest = " breaking_match_filter " ,
action = " append " ,
help = ' Same as " --match-filters " but stops the download process when a video is rejected ' ,
)
2014-09-13 07:55:21 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-break-match-filters " ,
dest = " breaking_match_filter " ,
action = " store_const " ,
const = None ,
help = " Do not use any --break-match-filters (default) " ,
)
2015-02-24 17:25:02 +01:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-playlist " ,
action = " store_true " ,
dest = " noplaylist " ,
default = False ,
help = " Download only the video, if the URL refers to a video and a playlist " ,
)
2015-02-24 17:25:02 +01:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --yes-playlist " ,
action = " store_false " ,
dest = " noplaylist " ,
help = " Download the playlist, if the URL refers to a video and a playlist " ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --age-limit " ,
metavar = " YEARS " ,
dest = " age_limit " ,
default = None ,
type = int ,
help = " Download only videos suitable for the given age " ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --download-archive " ,
metavar = " FILE " ,
dest = " download_archive " ,
help = " Download only videos not listed in the archive file. Record the IDs of all downloaded videos in it " ,
)
2021-11-29 02:52:52 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-download-archive " ,
dest = " download_archive " ,
action = " store_const " ,
const = None ,
help = " Do not use archive file (default) " ,
)
2021-11-29 02:52:52 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --max-downloads " ,
dest = " max_downloads " ,
metavar = " NUMBER " ,
type = int ,
default = None ,
help = " Abort after downloading NUMBER files " ,
)
2020-09-21 20:56:18 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --break-on-existing " ,
action = " store_true " ,
dest = " break_on_existing " ,
default = False ,
help = " Stop the download process when encountering a file that is in the archive " ,
)
2021-01-13 06:31:01 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --break-on-reject " ,
action = " store_true " ,
dest = " break_on_reject " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2021-11-29 02:41:55 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --break-per-input " ,
action = " store_true " ,
dest = " break_per_url " ,
default = False ,
help = " Alters --max-downloads, --break-on-existing, --break-match-filter, and autonumber to reset per input URL " ,
)
2021-11-29 02:41:55 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-break-per-input " ,
action = " store_false " ,
dest = " break_per_url " ,
help = " --break-on-existing and similar options terminates the entire download queue " ,
)
2021-04-21 11:30:43 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --skip-playlist-after-errors " ,
metavar = " N " ,
dest = " skip_playlist_after_errors " ,
default = None ,
type = int ,
help = " Number of allowed failures until the rest of the playlist is skipped " ,
)
2014-10-12 23:10:11 +02:00
selection . add_option (
2023-03-18 16:59:11 +01:00
" --include-ads " ,
dest = " include_ads " ,
action = " store_true " ,
help = optparse . SUPPRESS_HELP ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
selection . add_option (
2023-03-18 16:59:11 +01:00
" --no-include-ads " ,
dest = " include_ads " ,
action = " store_false " ,
help = optparse . SUPPRESS_HELP ,
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
authentication = optparse . OptionGroup ( parser , " Authentication Options " )
2014-10-12 23:10:11 +02:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" -u " ,
" --username " ,
dest = " username " ,
metavar = " USERNAME " ,
help = " Login with this account ID " ,
)
2014-10-12 23:10:11 +02:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" -p " ,
" --password " ,
dest = " password " ,
metavar = " PASSWORD " ,
help = " Account password. If this option is left out, yt-dlp will ask interactively " ,
)
2014-10-12 23:10:11 +02:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" -2 " ,
" --twofactor " ,
dest = " twofactor " ,
metavar = " TWOFACTOR " ,
help = " Two-factor authentication code " ,
)
2014-10-12 23:10:11 +02:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" -n " ,
" --netrc " ,
action = " store_true " ,
dest = " usenetrc " ,
default = False ,
help = " Use .netrc authentication data " ,
)
2021-09-16 00:51:40 +05:30
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --netrc-location " ,
dest = " netrc_location " ,
metavar = " PATH " ,
help = " Location of .netrc authentication data; either the path or its containing directory. Defaults to ~/.netrc " ,
)
2014-10-12 23:10:11 +02:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --video-password " ,
dest = " videopassword " ,
metavar = " PASSWORD " ,
help = " Video password (vimeo, youku) " ,
)
2021-04-11 05:52:55 +05:30
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --ap-mso " ,
dest = " ap_mso " ,
metavar = " MSO " ,
help = " Adobe Pass multiple-system operator (TV provider) identifier, use --ap-list-mso for a list of available MSOs " ,
)
2021-04-11 05:52:55 +05:30
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --ap-username " ,
dest = " ap_username " ,
metavar = " USERNAME " ,
help = " Multiple-system operator account login " ,
)
2021-04-11 05:52:55 +05:30
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --ap-password " ,
dest = " ap_password " ,
metavar = " PASSWORD " ,
help = " Multiple-system operator account password. If this option is left out, yt-dlp will ask interactively " ,
)
2021-04-11 05:52:55 +05:30
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --ap-list-mso " ,
action = " store_true " ,
dest = " ap_list_mso " ,
default = False ,
help = " List all supported multiple-system operators " ,
)
2022-05-02 19:59:45 +12:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --client-certificate " ,
dest = " client_certificate " ,
metavar = " CERTFILE " ,
help = " Path to client certificate file in PEM format. May include the private key " ,
)
2022-05-02 19:59:45 +12:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --client-certificate-key " ,
dest = " client_certificate_key " ,
metavar = " KEYFILE " ,
help = " Path to private key file for client certificate " ,
)
2022-05-02 19:59:45 +12:00
authentication . add_option (
2023-03-18 16:59:11 +01:00
" --client-certificate-password " ,
dest = " client_certificate_password " ,
metavar = " PASSWORD " ,
help = " Password for client certificate private key, if encrypted. "
" If not provided, and the key is encrypted, yt-dlp will ask interactively " ,
)
2014-10-12 23:10:11 +02:00
2023-03-18 16:59:11 +01:00
video_format = optparse . OptionGroup ( parser , " Video Format Options " )
2014-10-12 23:10:11 +02:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" -f " ,
" --format " ,
action = " store " ,
dest = " format " ,
metavar = " FORMAT " ,
default = None ,
help = ' Video format code, see " FORMAT SELECTION " for more details ' ,
)
Better Format Sorting (Squashed)
* Added --format-sort (-S height,filesize)
* Made fields reversible (-S +height)
* Added --format-sort-force, --no-format-sort-force
* Added limit (-S height:720)
* Added codec preference (-S vcodec,acodec)
* Correct handling of preference<-1000
* Rebased to yt-dlc
* Automatically determine missing bitrates
* aext, vext, protocol, acodec, vcodec can now takes priority as string, not number (-S vext:webm)
* Correct handling of None in codec, audio_codec (None means the codec is unknown while 'none' means it doesn't exist)
* Correctly parse filesize (-S filesize:200M)
* Generalized preference calculation
* Rewrote entire code into the class FormatSort
* Correctly handle user input errors
* Combined fields (-S +ext:webm:webm)
* Closest mode (-S filesize~50M)
* Aliases (framerate=fps, br=bitrate etc)
* Documentation
2020-10-26 21:20:09 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" -S " ,
" --format-sort " ,
metavar = " SORTORDER " ,
dest = " format_sort " ,
default = [ ] ,
type = " str " ,
action = " callback " ,
callback = _list_from_options_callback ,
callback_kwargs = { " append " : - 1 } ,
help = ' Sort the formats by the fields given, see " Sorting Formats " for more details ' ,
)
Better Format Sorting (Squashed)
* Added --format-sort (-S height,filesize)
* Made fields reversible (-S +height)
* Added --format-sort-force, --no-format-sort-force
* Added limit (-S height:720)
* Added codec preference (-S vcodec,acodec)
* Correct handling of preference<-1000
* Rebased to yt-dlc
* Automatically determine missing bitrates
* aext, vext, protocol, acodec, vcodec can now takes priority as string, not number (-S vext:webm)
* Correct handling of None in codec, audio_codec (None means the codec is unknown while 'none' means it doesn't exist)
* Correctly parse filesize (-S filesize:200M)
* Generalized preference calculation
* Rewrote entire code into the class FormatSort
* Correctly handle user input errors
* Combined fields (-S +ext:webm:webm)
* Closest mode (-S filesize~50M)
* Aliases (framerate=fps, br=bitrate etc)
* Documentation
2020-10-26 21:20:09 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --format-sort-force " ,
" --S-force " ,
action = " store_true " ,
dest = " format_sort_force " ,
metavar = " FORMAT " ,
default = False ,
Better Format Sorting (Squashed)
* Added --format-sort (-S height,filesize)
* Made fields reversible (-S +height)
* Added --format-sort-force, --no-format-sort-force
* Added limit (-S height:720)
* Added codec preference (-S vcodec,acodec)
* Correct handling of preference<-1000
* Rebased to yt-dlc
* Automatically determine missing bitrates
* aext, vext, protocol, acodec, vcodec can now takes priority as string, not number (-S vext:webm)
* Correct handling of None in codec, audio_codec (None means the codec is unknown while 'none' means it doesn't exist)
* Correctly parse filesize (-S filesize:200M)
* Generalized preference calculation
* Rewrote entire code into the class FormatSort
* Correctly handle user input errors
* Combined fields (-S +ext:webm:webm)
* Closest mode (-S filesize~50M)
* Aliases (framerate=fps, br=bitrate etc)
* Documentation
2020-10-26 21:20:09 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Force user specified sort order to have precedence over all fields, "
' see " Sorting Formats " for more details (Alias: --S-force) '
) ,
)
Better Format Sorting (Squashed)
* Added --format-sort (-S height,filesize)
* Made fields reversible (-S +height)
* Added --format-sort-force, --no-format-sort-force
* Added limit (-S height:720)
* Added codec preference (-S vcodec,acodec)
* Correct handling of preference<-1000
* Rebased to yt-dlc
* Automatically determine missing bitrates
* aext, vext, protocol, acodec, vcodec can now takes priority as string, not number (-S vext:webm)
* Correct handling of None in codec, audio_codec (None means the codec is unknown while 'none' means it doesn't exist)
* Correctly parse filesize (-S filesize:200M)
* Generalized preference calculation
* Rewrote entire code into the class FormatSort
* Correctly handle user input errors
* Combined fields (-S +ext:webm:webm)
* Closest mode (-S filesize~50M)
* Aliases (framerate=fps, br=bitrate etc)
* Documentation
2020-10-26 21:20:09 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-format-sort-force " ,
action = " store_false " ,
dest = " format_sort_force " ,
metavar = " FORMAT " ,
default = False ,
help = " Some fields have precedence over the user specified sort order (default) " ,
)
Better Format Selection
* Added options: --video-multistreams, --no-video-multistreams, --audio-multistreams, --no-audio-multistreams
* New format selectors: best*, worst*, bestvideo*, bestaudio*, worstvideo*, worstaudio*
* Added b,w,v,a as alias for best, worst, video and audio respectively in format selection
* Changed video format sorting to show video only files and video+audio files together.
2020-11-05 21:05:36 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --video-multistreams " ,
action = " store_true " ,
dest = " allow_multiple_video_streams " ,
default = None ,
help = " Allow multiple video streams to be merged into a single file " ,
)
Better Format Selection
* Added options: --video-multistreams, --no-video-multistreams, --audio-multistreams, --no-audio-multistreams
* New format selectors: best*, worst*, bestvideo*, bestaudio*, worstvideo*, worstaudio*
* Added b,w,v,a as alias for best, worst, video and audio respectively in format selection
* Changed video format sorting to show video only files and video+audio files together.
2020-11-05 21:05:36 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-video-multistreams " ,
action = " store_false " ,
dest = " allow_multiple_video_streams " ,
help = " Only one video stream is downloaded for each output file (default) " ,
)
Better Format Selection
* Added options: --video-multistreams, --no-video-multistreams, --audio-multistreams, --no-audio-multistreams
* New format selectors: best*, worst*, bestvideo*, bestaudio*, worstvideo*, worstaudio*
* Added b,w,v,a as alias for best, worst, video and audio respectively in format selection
* Changed video format sorting to show video only files and video+audio files together.
2020-11-05 21:05:36 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --audio-multistreams " ,
action = " store_true " ,
dest = " allow_multiple_audio_streams " ,
default = None ,
help = " Allow multiple audio streams to be merged into a single file " ,
)
Better Format Selection
* Added options: --video-multistreams, --no-video-multistreams, --audio-multistreams, --no-audio-multistreams
* New format selectors: best*, worst*, bestvideo*, bestaudio*, worstvideo*, worstaudio*
* Added b,w,v,a as alias for best, worst, video and audio respectively in format selection
* Changed video format sorting to show video only files and video+audio files together.
2020-11-05 21:05:36 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-audio-multistreams " ,
action = " store_false " ,
dest = " allow_multiple_audio_streams " ,
help = " Only one audio stream is downloaded for each output file (default) " ,
)
2014-10-12 23:10:11 +02:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --all-formats " ,
action = " store_const " ,
dest = " format " ,
const = " all " ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --prefer-free-formats " ,
action = " store_true " ,
dest = " prefer_free_formats " ,
default = False ,
2021-02-18 19:47:46 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Prefer video formats with free containers over non-free ones of same quality. "
' Use with " -S ext " to strictly prefer free containers irrespective of quality '
) ,
)
2021-02-18 19:47:46 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-prefer-free-formats " ,
action = " store_false " ,
dest = " prefer_free_formats " ,
default = False ,
help = " Don ' t give any special preference to free containers (default) " ,
)
2021-05-04 21:24:00 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --check-formats " ,
action = " store_const " ,
const = " selected " ,
dest = " check_formats " ,
default = None ,
help = " Make sure formats are selected only from those that are actually downloadable " ,
)
2021-10-24 14:46:07 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --check-all-formats " ,
action = " store_true " ,
dest = " check_formats " ,
help = " Check all formats for whether they are actually downloadable " ,
)
2021-07-15 22:49:59 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-check-formats " ,
action = " store_false " ,
dest = " check_formats " ,
help = " Do not check that the formats are actually downloadable " ,
)
2014-10-12 23:10:11 +02:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" -F " ,
" --list-formats " ,
action = " store_true " ,
dest = " listformats " ,
help = " List available formats of each video. Simulate unless --no-simulate is used " ,
)
2020-12-13 19:59:09 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --list-formats-as-table " ,
action = " store_true " ,
dest = " listformats_table " ,
default = True ,
help = optparse . SUPPRESS_HELP ,
)
2020-12-13 19:59:09 +05:30
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --list-formats-old " ,
" --no-list-formats-as-table " ,
action = " store_false " ,
dest = " listformats_table " ,
help = optparse . SUPPRESS_HELP ,
)
2015-01-09 22:03:56 +00:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --merge-output-format " ,
action = " store " ,
dest = " merge_output_format " ,
metavar = " FORMAT " ,
default = None ,
2015-01-09 22:03:56 +00:00
help = (
2022-08-14 21:04:13 +09:00
' Containers that may be used when merging formats, separated by " / " , e.g. " mp4/mkv " . '
2023-03-18 16:59:11 +01:00
" Ignored if no merge is required. "
f ' (currently supported: { " , " . join ( sorted ( FFmpegMergerPP . SUPPORTED_EXTS ) ) } ) '
) ,
)
2021-02-11 22:51:59 -05:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --allow-unplayable-formats " ,
action = " store_true " ,
dest = " allow_unplayable_formats " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2021-02-11 22:51:59 -05:00
video_format . add_option (
2023-03-18 16:59:11 +01:00
" --no-allow-unplayable-formats " ,
action = " store_false " ,
dest = " allow_unplayable_formats " ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
2023-03-18 16:59:11 +01:00
subtitles = optparse . OptionGroup ( parser , " Subtitle Options " )
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --write-subs " ,
" --write-srt " ,
action = " store_true " ,
dest = " writesubtitles " ,
default = False ,
help = " Write subtitle file " ,
)
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-subs " ,
" --no-write-srt " ,
action = " store_false " ,
dest = " writesubtitles " ,
help = " Do not write subtitle file (default) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --write-auto-subs " ,
" --write-automatic-subs " ,
action = " store_true " ,
dest = " writeautomaticsub " ,
default = False ,
help = " Write automatically generated subtitle file (Alias: --write-automatic-subs) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-auto-subs " ,
" --no-write-automatic-subs " ,
action = " store_false " ,
dest = " writeautomaticsub " ,
default = False ,
help = " Do not write auto-generated subtitles (default) (Alias: --no-write-automatic-subs) " ,
)
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --all-subs " ,
action = " store_true " ,
dest = " allsubtitles " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --list-subs " ,
action = " store_true " ,
dest = " listsubtitles " ,
default = False ,
help = " List available subtitles of each video. Simulate unless --no-simulate is used " ,
)
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --sub-format " ,
action = " store " ,
dest = " subtitlesformat " ,
metavar = " FORMAT " ,
default = " best " ,
help = ' Subtitle format; accepts formats preference, e.g. " srt " or " ass/srt/best " ' ,
)
2014-10-12 23:10:11 +02:00
subtitles . add_option (
2023-03-18 16:59:11 +01:00
" --sub-langs " ,
" --srt-langs " ,
action = " callback " ,
dest = " subtitleslangs " ,
metavar = " LANGS " ,
type = " str " ,
default = [ ] ,
callback = _list_from_options_callback ,
2021-04-20 02:47:09 +05:30
help = (
2022-08-14 21:04:13 +09:00
' Languages of the subtitles to download (can be regex) or " all " separated by commas, e.g. --sub-langs " en.*,ja " . '
' You can prefix the language code with a " - " to exclude it from the requested languages, e.g. --sub-langs all,-live_chat. '
2023-03-18 16:59:11 +01:00
" Use --list-subs for a list of available language tags "
) ,
)
2014-10-12 23:10:11 +02:00
2023-03-18 16:59:11 +01:00
downloader = optparse . OptionGroup ( parser , " Download Options " )
2021-03-12 23:46:58 -05:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" -N " ,
" --concurrent-fragments " ,
dest = " concurrent_fragment_downloads " ,
metavar = " N " ,
default = 1 ,
type = int ,
help = " Number of fragments of a dash/hlsnative video that should be downloaded concurrently (default is %d efault) " ,
)
2014-10-12 23:10:11 +02:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" -r " ,
" --limit-rate " ,
" --rate-limit " ,
dest = " ratelimit " ,
metavar = " RATE " ,
help = " Maximum download rate in bytes per second, e.g. 50K or 4.2M " ,
)
2021-06-23 04:41:09 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --throttled-rate " ,
dest = " throttledratelimit " ,
metavar = " RATE " ,
help = " Minimum download rate in bytes per second below which throttling is assumed and the video data is re-extracted, e.g. 100K " ,
)
2014-10-12 23:10:11 +02:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" -R " ,
" --retries " ,
dest = " retries " ,
metavar = " RETRIES " ,
default = 10 ,
help = ' Number of retries (default is %d efault), or " infinite " ' ,
)
2021-12-23 03:29:03 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --file-access-retries " ,
dest = " file_access_retries " ,
metavar = " RETRIES " ,
default = 3 ,
help = ' Number of times to retry on file access error (default is %d efault), or " infinite " ' ,
)
2016-03-19 20:40:36 +06:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --fragment-retries " ,
dest = " fragment_retries " ,
metavar = " RETRIES " ,
default = 10 ,
help = ' Number of retries for a fragment (default is %d efault), or " infinite " (DASH, hlsnative and ISM) ' ,
)
2022-05-19 20:00:31 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --retry-sleep " ,
dest = " retry_sleep " ,
metavar = " [TYPE:]EXPR " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2022-05-19 20:00:31 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : " http|fragment|file_access|extractor " ,
" default_key " : " http " ,
} ,
help = (
" Time to sleep between retries in seconds (optionally) prefixed by the type of retry "
" (http (default), fragment, file_access, extractor) to apply the sleep to. "
" EXPR can be a number, linear=START[:END[:STEP=1]] or exp=START[:END[:BASE=2]]. "
" This option can be used multiple times to set the sleep for the different retry types, "
" e.g. --retry-sleep linear=1::2 --retry-sleep fragment:exp=1:20 "
) ,
)
2016-08-27 04:52:18 +07:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --skip-unavailable-fragments " ,
" --no-abort-on-unavailable-fragments " ,
action = " store_true " ,
dest = " skip_unavailable_fragments " ,
default = True ,
help = " Skip unavailable fragments for DASH, hlsnative and ISM downloads (default) (Alias: --no-abort-on-unavailable-fragments) " ,
)
2017-01-28 21:06:22 +07:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --abort-on-unavailable-fragments " ,
" --no-skip-unavailable-fragments " ,
action = " store_false " ,
dest = " skip_unavailable_fragments " ,
help = " Abort download if a fragment is unavailable (Alias: --no-skip-unavailable-fragments) " ,
)
2017-04-24 03:09:08 +07:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --keep-fragments " ,
action = " store_true " ,
dest = " keep_fragments " ,
default = False ,
help = " Keep downloaded fragments on disk after downloading is finished " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --no-keep-fragments " ,
action = " store_false " ,
dest = " keep_fragments " ,
help = " Delete downloaded fragments after downloading is finished (default) " ,
)
2014-10-12 23:10:11 +02:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --buffer-size " ,
dest = " buffersize " ,
metavar = " SIZE " ,
default = " 1024 " ,
help = " Size of download buffer, e.g. 1024 or 16K (default is %d efault) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --resize-buffer " ,
action = " store_false " ,
dest = " noresizebuffer " ,
help = " The buffer size is automatically resized from an initial value of --buffer-size (default) " ,
)
2014-10-12 23:10:11 +02:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --no-resize-buffer " ,
action = " store_true " ,
dest = " noresizebuffer " ,
default = False ,
help = " Do not automatically adjust the buffer size " ,
)
2018-01-28 13:21:45 +07:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --http-chunk-size " ,
dest = " http_chunk_size " ,
metavar = " SIZE " ,
default = None ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Size of a chunk for chunk-based HTTP downloading, e.g. 10485760 or 10M (default is disabled). "
" May be useful for bypassing bandwidth throttling imposed by a webserver (experimental) "
) ,
)
2014-10-12 23:10:11 +02:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --test " ,
action = " store_true " ,
dest = " test " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-07-10 20:11:11 -07:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --playlist-reverse " ,
action = " store_true " ,
dest = " playlist_reverse " ,
help = optparse . SUPPRESS_HELP ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --no-playlist-reverse " ,
action = " store_false " ,
dest = " playlist_reverse " ,
help = optparse . SUPPRESS_HELP ,
)
2017-01-31 10:03:31 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --playlist-random " ,
action = " store_true " ,
dest = " playlist_random " ,
help = " Download playlist videos in random order " ,
)
2022-06-17 13:35:04 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --lazy-playlist " ,
action = " store_true " ,
dest = " lazy_playlist " ,
help = " Process entries in the playlist as they are received. This disables n_entries, --playlist-random and --playlist-reverse " ,
)
2022-06-17 13:35:04 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --no-lazy-playlist " ,
action = " store_false " ,
dest = " lazy_playlist " ,
help = " Process videos in the playlist only after the entire playlist is parsed (default) " ,
)
2015-01-25 04:49:44 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --xattr-set-filesize " ,
dest = " xattr_set_filesize " ,
action = " store_true " ,
help = " Set file xattribute ytdl.filesize with expected file size " ,
)
2015-02-17 12:09:12 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --hls-prefer-native " ,
dest = " hls_prefer_native " ,
action = " store_true " ,
default = None ,
help = optparse . SUPPRESS_HELP ,
)
2016-04-21 23:02:17 +06:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --hls-prefer-ffmpeg " ,
dest = " hls_prefer_native " ,
action = " store_false " ,
default = None ,
help = optparse . SUPPRESS_HELP ,
)
2016-01-30 12:26:40 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --hls-use-mpegts " ,
dest = " hls_use_mpegts " ,
action = " store_true " ,
default = None ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Use the mpegts container for HLS videos; "
" allowing some players to play the video while downloading, "
" and reducing the chance of file corruption if download is interrupted. "
" This is enabled by default for live streams "
) ,
)
2021-02-26 21:51:31 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --no-hls-use-mpegts " ,
dest = " hls_use_mpegts " ,
action = " store_false " ,
2021-02-26 21:51:31 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Do not use the mpegts container for HLS videos. "
" This is default when not downloading live streams "
) ,
)
2022-06-07 01:43:50 +05:30
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --download-sections " ,
metavar = " REGEX " ,
dest = " download_ranges " ,
action = " append " ,
2022-06-07 01:43:50 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Download only chapters whose title matches the given regular expression. "
2022-06-07 01:43:50 +05:30
' Time ranges prefixed by a " * " can also be used in place of chapters to download the specified range. '
2023-03-18 16:59:11 +01:00
" Needs ffmpeg. This option can be used multiple times to download multiple sections, "
' e.g. --download-sections " *10:15-inf " --download-sections " intro " '
) ,
)
2015-01-24 01:38:48 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --downloader " ,
" --external-downloader " ,
dest = " external_downloader " ,
metavar = " [PROTO:]NAME " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-04-10 20:38:33 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : " http|ftp|m3u8|dash|rtsp|rtmp|mms " ,
" default_key " : " default " ,
" process " : str . strip ,
} ,
help = (
" Name or path of the external downloader to use (optionally) prefixed by "
" the protocols (http, ftp, m3u8, dash, rstp, rtmp, mms) to use it for. "
2022-07-31 02:15:22 +05:30
f ' Currently supports native, { " , " . join ( sorted ( list_external_downloaders ( ) ) ) } . '
2023-03-18 16:59:11 +01:00
" You can use this option multiple times to set different downloaders for different protocols. "
2022-08-14 21:04:13 +09:00
' E.g. --downloader aria2c --downloader " dash,m3u8:native " will use '
2023-03-18 16:59:11 +01:00
" aria2c for http/ftp downloads, and the native downloader for dash/m3u8 downloads "
" (Alias: --external-downloader) "
) ,
)
2015-03-02 15:06:09 +01:00
downloader . add_option (
2023-03-18 16:59:11 +01:00
" --downloader-args " ,
" --external-downloader-args " ,
metavar = " NAME:ARGS " ,
dest = " external_downloader_args " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-01-23 17:41:21 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : r " ffmpeg_[io] \ d*| %s "
% " | " . join ( map ( re . escape , list_external_downloaders ( ) ) ) ,
" default_key " : " default " ,
" process " : shlex . split ,
} ,
help = (
" Give these arguments to the external downloader. "
2021-01-23 11:29:20 +05:30
' Specify the downloader name and the arguments separated by a colon " : " . '
2023-03-18 16:59:11 +01:00
" For ffmpeg, arguments can be passed to different positions using the same syntax as --postprocessor-args. "
" You can use this option multiple times to give different arguments to different downloaders "
" (Alias: --external-downloader-args) "
) ,
)
2014-10-12 23:10:11 +02:00
2023-03-18 16:59:11 +01:00
workarounds = optparse . OptionGroup ( parser , " Workarounds " )
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --encoding " ,
dest = " encoding " ,
metavar = " ENCODING " ,
help = " Force the specified encoding (experimental) " ,
)
2022-01-21 15:12:30 +09:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --legacy-server-connect " ,
action = " store_true " ,
dest = " legacy_server_connect " ,
default = False ,
help = " Explicitly allow HTTPS connection to servers that do not support RFC 5746 secure renegotiation " ,
)
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --no-check-certificates " ,
action = " store_true " ,
dest = " no_check_certificate " ,
default = False ,
help = " Suppress HTTPS certificate validation " ,
)
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --prefer-insecure " ,
" --prefer-unsecure " ,
action = " store_true " ,
dest = " prefer_insecure " ,
help = " Use an unencrypted connection to retrieve information about the video (Currently supported only for YouTube) " ,
)
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --user-agent " , metavar = " UA " , dest = " user_agent " , help = optparse . SUPPRESS_HELP
)
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --referer " ,
metavar = " URL " ,
dest = " referer " ,
default = None ,
help = optparse . SUPPRESS_HELP ,
)
2014-09-13 07:55:21 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --add-headers " ,
metavar = " FIELD:VALUE " ,
dest = " headers " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
callback_kwargs = { " multiple_keys " : False } ,
2021-01-23 11:27:27 +05:30
help = ' Specify a custom HTTP header and its value, separated by a colon " : " . You can use this option multiple times ' ,
2014-09-13 07:55:21 +02:00
)
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --bidi-workaround " ,
dest = " bidi_workaround " ,
action = " store_true " ,
help = " Work around terminals that lack bidirectional text support. Requires bidiv or fribidi executable in PATH " ,
)
2021-02-27 18:11:23 +05:30
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --sleep-requests " ,
metavar = " SECONDS " ,
dest = " sleep_interval_requests " ,
type = float ,
help = " Number of seconds to sleep between requests during data extraction " ,
)
2015-01-23 12:05:01 +01:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --sleep-interval " ,
" --min-sleep-interval " ,
metavar = " SECONDS " ,
dest = " sleep_interval " ,
type = float ,
2016-08-09 03:46:52 +07:00
help = (
2023-03-18 16:59:11 +01:00
" Number of seconds to sleep before each download. "
" This is the minimum time to sleep when used along with --max-sleep-interval "
" (Alias: --min-sleep-interval) "
) ,
)
2016-08-04 15:47:22 +05:30
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --max-sleep-interval " ,
metavar = " SECONDS " ,
dest = " max_sleep_interval " ,
type = float ,
help = " Maximum number of seconds to sleep. Can only be used along with --min-sleep-interval " ,
)
2020-09-29 05:11:32 +02:00
workarounds . add_option (
2023-03-18 16:59:11 +01:00
" --sleep-subtitles " ,
metavar = " SECONDS " ,
dest = " sleep_interval_subtitles " ,
default = 0 ,
type = int ,
help = " Number of seconds to sleep before each subtitle download " ,
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
verbosity = optparse . OptionGroup ( parser , " Verbosity and Simulation Options " )
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -q " ,
" --quiet " ,
action = " store_true " ,
dest = " quiet " ,
default = False ,
help = " Activate quiet mode. If used with --verbose, print the log to stderr " ,
)
2014-09-13 07:55:21 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --no-warnings " ,
dest = " no_warnings " ,
action = " store_true " ,
default = False ,
help = " Ignore warnings " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -s " ,
" --simulate " ,
action = " store_true " ,
dest = " simulate " ,
default = None ,
help = " Do not download the video and do not write anything to disk " ,
)
2021-08-07 05:31:51 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --no-simulate " ,
action = " store_false " ,
dest = " simulate " ,
help = " Download the video even if printing/listing options are used " ,
)
2021-04-17 05:39:58 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --ignore-no-formats-error " ,
action = " store_true " ,
dest = " ignore_no_formats_error " ,
default = False ,
2021-04-17 05:39:58 +05:30
help = (
2021-10-31 14:45:59 +05:30
' Ignore " No video formats " error. Useful for extracting metadata '
2023-03-18 16:59:11 +01:00
" even if the videos are not actually available for download (experimental) "
) ,
)
2021-04-17 05:39:58 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --no-ignore-no-formats-error " ,
action = " store_false " ,
dest = " ignore_no_formats_error " ,
help = " Throw error when no downloadable video formats are found (default) " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --skip-download " ,
" --no-download " ,
action = " store_true " ,
dest = " skip_download " ,
default = False ,
help = " Do not download the video but write all related files (Alias: --no-download) " ,
)
2021-05-14 13:14:38 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -O " ,
" --print " ,
metavar = " [WHEN:]TEMPLATE " ,
dest = " forceprint " ,
* * when_prefix ( " video " ) ,
2022-12-30 11:15:41 +05:30
help = (
2022-01-10 23:57:59 +05:30
' Field name or output template to print to screen, optionally prefixed with when to print it, separated by a " : " . '
2022-12-30 11:15:41 +05:30
' Supported values of " WHEN " are the same as that of --use-postprocessor (default: video). '
2023-03-18 16:59:11 +01:00
" Implies --quiet. Implies --simulate unless --no-simulate or later stages of WHEN are used. "
" This option can be used multiple times "
) ,
)
2022-01-24 03:04:19 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --print-to-file " ,
metavar = " [WHEN:]TEMPLATE FILE " ,
dest = " print_to_file " ,
nargs = 2 ,
* * when_prefix ( " video " ) ,
2022-12-30 11:15:41 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Append given template to the file. The values of WHEN and TEMPLATE are same as that of --print. "
" FILE uses the same syntax as the output template. This option can be used multiple times "
) ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -g " ,
" --get-url " ,
action = " store_true " ,
dest = " geturl " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -e " ,
" --get-title " ,
action = " store_true " ,
dest = " gettitle " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-id " ,
action = " store_true " ,
dest = " getid " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-thumbnail " ,
action = " store_true " ,
dest = " getthumbnail " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-description " ,
action = " store_true " ,
dest = " getdescription " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-duration " ,
action = " store_true " ,
dest = " getduration " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-filename " ,
action = " store_true " ,
dest = " getfilename " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --get-format " ,
action = " store_true " ,
dest = " getformat " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -j " ,
" --dump-json " ,
action = " store_true " ,
dest = " dumpjson " ,
default = False ,
help = ' Quiet, but print JSON information for each video. Simulate unless --no-simulate is used. See " OUTPUT TEMPLATE " for a description of available keys ' ,
)
2014-10-25 00:30:57 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -J " ,
" --dump-single-json " ,
action = " store_true " ,
dest = " dump_single_json " ,
default = False ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Quiet, but print JSON information for each url or infojson passed. Simulate unless --no-simulate is used. "
" If the URL refers to a playlist, the whole playlist information is dumped in a single line "
) ,
)
2015-01-08 18:01:41 +01:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --print-json " ,
action = " store_true " ,
dest = " print_json " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2020-11-05 23:13:21 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --force-write-archive " ,
" --force-write-download-archive " ,
" --force-download-archive " ,
action = " store_true " ,
dest = " force_write_download_archive " ,
default = False ,
2020-11-05 23:13:21 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Force download archive entries to be written as far as no errors occur, "
" even if -s or another simulation option is used (Alias: --force-download-archive) "
) ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --newline " ,
action = " store_true " ,
dest = " progress_with_newline " ,
default = False ,
help = " Output progress bar as new lines " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --no-progress " ,
action = " store_true " ,
dest = " noprogress " ,
default = None ,
help = " Do not print progress bar " ,
)
2021-10-09 00:41:59 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --progress " ,
action = " store_false " ,
dest = " noprogress " ,
help = " Show progress bar, even if in quiet mode " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --console-title " ,
action = " store_true " ,
dest = " consoletitle " ,
default = False ,
help = " Display progress in console titlebar " ,
)
2021-10-09 00:41:59 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --progress-template " ,
metavar = " [TYPES:]TEMPLATE " ,
dest = " progress_template " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-10-09 00:41:59 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : " (download|postprocess)(-title)? " ,
" default_key " : " download " ,
} ,
help = (
2021-10-09 00:41:59 +05:30
' Template for progress outputs, optionally prefixed with one of " download: " (default), '
' " download-title: " (the console title), " postprocess: " , or " postprocess-title: " . '
' The video \' s fields are accessible under the " info " key and '
2022-08-14 21:04:13 +09:00
' the progress attributes are accessible under " progress " key. E.g. '
2021-10-09 00:41:59 +05:30
# TODO: Document the fields inside "progress"
2023-03-18 16:59:11 +01:00
' --console-title --progress-template " download-title: % (info.id)s- % (progress.eta)s " '
) ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -v " ,
" --verbose " ,
action = " store_true " ,
dest = " verbose " ,
default = False ,
help = " Print various debugging information " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --dump-pages " ,
" --dump-intermediate-pages " ,
action = " store_true " ,
dest = " dump_intermediate_pages " ,
default = False ,
help = " Print downloaded pages encoded using base64 to debug problems (very verbose) " ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --write-pages " ,
action = " store_true " ,
dest = " write_pages " ,
default = False ,
help = " Write downloaded intermediary pages to files in the current directory to debug problems " ,
)
2022-06-01 02:03:22 +05:30
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --load-pages " ,
action = " store_true " ,
dest = " load_pages " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --youtube-print-sig-code " ,
action = " store_true " ,
dest = " youtube_print_sig_code " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --print-traffic " ,
" --dump-headers " ,
dest = " debug_printtraffic " ,
action = " store_true " ,
default = False ,
help = " Display sent and read HTTP traffic " ,
)
2015-01-10 21:02:27 +01:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" -C " ,
" --call-home " ,
dest = " call_home " ,
action = " store_true " ,
default = False ,
2022-04-18 02:28:28 +05:30
# help='Contact the yt-dlp server for debugging')
2023-03-18 16:59:11 +01:00
help = optparse . SUPPRESS_HELP ,
)
2015-01-10 21:09:15 +01:00
verbosity . add_option (
2023-03-18 16:59:11 +01:00
" --no-call-home " ,
dest = " call_home " ,
action = " store_false " ,
2021-02-24 15:45:56 -03:00
# help='Do not contact the yt-dlp server for debugging (default)')
2023-03-18 16:59:11 +01:00
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
2023-03-18 16:59:11 +01:00
filesystem = optparse . OptionGroup ( parser , " Filesystem Options " )
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" -a " ,
" --batch-file " ,
dest = " batchfile " ,
metavar = " FILE " ,
2021-12-18 04:28:18 +05:30
help = (
' File containing URLs to download ( " - " for stdin), one URL per line. '
2023-03-18 16:59:11 +01:00
' Lines starting with " # " , " ; " or " ] " are considered as comments and ignored '
) ,
)
2021-10-18 21:11:07 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-batch-file " ,
dest = " batchfile " ,
action = " store_const " ,
const = None ,
help = " Do not read URLs from batch file (default) " ,
)
2021-10-22 04:34:22 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --id " ,
default = False ,
action = " store_true " ,
dest = " useid " ,
help = optparse . SUPPRESS_HELP ,
)
2021-01-23 17:48:12 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" -P " ,
" --paths " ,
metavar = " [TYPES:]PATH " ,
dest = " paths " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-07-31 19:00:32 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : " home|temp| %s "
% " | " . join ( map ( re . escape , OUTTMPL_TYPES . keys ( ) ) ) ,
" default_key " : " home " ,
} ,
help = (
" The paths where the files should be downloaded. "
2021-02-03 19:06:09 +05:30
' Specify the type of file and the path separated by a colon " : " . '
2023-03-18 16:59:11 +01:00
" All the same TYPES as --output are supported. "
2021-07-31 19:00:32 +05:30
' Additionally, you can also provide " home " (default) and " temp " paths. '
2023-03-18 16:59:11 +01:00
" All intermediary files are first downloaded to the temp path and "
" then the final files are moved over to the home path after download is finished. "
" This option is ignored if --output is an absolute path "
) ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" -o " ,
" --output " ,
metavar = " [TYPES:]TEMPLATE " ,
dest = " outtmpl " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-02-03 19:06:09 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : " | " . join ( map ( re . escape , OUTTMPL_TYPES . keys ( ) ) ) ,
" default_key " : " default " ,
} ,
help = ' Output filename template; see " OUTPUT TEMPLATE " for details ' ,
)
2021-01-16 18:12:05 +01:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --output-na-placeholder " ,
dest = " outtmpl_na_placeholder " ,
metavar = " TEXT " ,
default = " NA " ,
help = (
' Placeholder for unavailable fields in " OUTPUT TEMPLATE " (default: " %d efault " ) '
) ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --autonumber-size " ,
dest = " autonumber_size " ,
metavar = " NUMBER " ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2016-05-01 12:34:11 +00:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --autonumber-start " ,
dest = " autonumber_start " ,
metavar = " NUMBER " ,
default = 1 ,
type = int ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --restrict-filenames " ,
action = " store_true " ,
dest = " restrictfilenames " ,
default = False ,
help = ' Restrict filenames to only ASCII characters, and avoid " & " and spaces in filenames ' ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-restrict-filenames " ,
action = " store_false " ,
dest = " restrictfilenames " ,
help = ' Allow Unicode characters, " & " and spaces in filenames (default) ' ,
)
2021-02-18 00:39:38 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --windows-filenames " ,
action = " store_true " ,
dest = " windowsfilenames " ,
default = False ,
help = " Force filenames to be Windows-compatible " ,
)
2021-02-18 00:39:38 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-windows-filenames " ,
action = " store_false " ,
dest = " windowsfilenames " ,
help = " Make filenames Windows-compatible only if using Windows (default) " ,
)
2021-02-18 00:39:38 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --trim-filenames " ,
" --trim-file-names " ,
metavar = " LENGTH " ,
dest = " trim_file_name " ,
default = 0 ,
type = int ,
help = " Limit the filename length (excluding extension) to the specified number of characters " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" -w " ,
" --no-overwrites " ,
action = " store_false " ,
dest = " overwrites " ,
default = None ,
help = " Do not overwrite any files " ,
)
2019-10-13 18:00:48 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --force-overwrites " ,
" --yes-overwrites " ,
action = " store_true " ,
dest = " overwrites " ,
help = " Overwrite all video and metadata files. This option includes --no-continue " ,
)
2019-10-13 18:00:48 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-force-overwrites " ,
action = " store_const " ,
dest = " overwrites " ,
const = None ,
help = " Do not overwrite the video, but overwrite related files (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" -c " ,
" --continue " ,
action = " store_true " ,
dest = " continue_dl " ,
default = True ,
help = " Resume partially downloaded files/fragments (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-continue " ,
action = " store_false " ,
dest = " continue_dl " ,
2021-02-05 04:23:04 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Do not resume partially downloaded fragments. "
" If the file is not fragmented, restart download of the entire file "
) ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --part " ,
action = " store_false " ,
dest = " nopart " ,
default = False ,
help = " Use .part files instead of writing directly into output file (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-part " ,
action = " store_true " ,
dest = " nopart " ,
help = " Do not use .part files - write directly into output file " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --mtime " ,
action = " store_true " ,
dest = " updatetime " ,
default = True ,
help = " Use the Last-modified header to set the file modification time (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-mtime " ,
action = " store_false " ,
dest = " updatetime " ,
help = " Do not use the Last-modified header to set the file modification time " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --write-description " ,
action = " store_true " ,
dest = " writedescription " ,
default = False ,
help = " Write video description to a .description file " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-description " ,
action = " store_false " ,
dest = " writedescription " ,
help = " Do not write video description (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --write-info-json " ,
action = " store_true " ,
dest = " writeinfojson " ,
default = None ,
help = " Write video metadata to a .info.json file (this may contain personal information) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-info-json " ,
action = " store_false " ,
dest = " writeinfojson " ,
help = " Do not write video metadata (default) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --write-annotations " ,
action = " store_true " ,
dest = " writeannotations " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-annotations " ,
action = " store_false " ,
dest = " writeannotations " ,
help = optparse . SUPPRESS_HELP ,
)
2021-01-30 16:43:20 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --write-playlist-metafiles " ,
action = " store_true " ,
dest = " allow_playlist_files " ,
default = None ,
2021-01-30 16:43:20 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Write playlist metadata in addition to the video metadata "
" when using --write-info-json, --write-description etc. (default) "
) ,
)
2021-01-30 16:43:20 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-playlist-metafiles " ,
action = " store_false " ,
dest = " allow_playlist_files " ,
help = " Do not write playlist metadata when using --write-info-json, --write-description etc. " ,
)
2021-03-18 20:57:20 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --clean-info-json " ,
" --clean-infojson " ,
action = " store_true " ,
dest = " clean_infojson " ,
default = None ,
2021-03-18 20:57:20 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Remove some private fields such as filenames from the infojson. "
" Note that it could still contain some personal information (default) "
) ,
)
2021-03-18 20:57:20 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-clean-info-json " ,
" --no-clean-infojson " ,
action = " store_false " ,
dest = " clean_infojson " ,
help = " Write all fields to the infojson " ,
)
2021-01-27 20:32:51 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --write-comments " ,
" --get-comments " ,
action = " store_true " ,
dest = " getcomments " ,
default = False ,
2021-02-28 20:26:08 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Retrieve video comments to be placed in the infojson. "
" The comments are fetched even without this option if the extraction is known to be quick (Alias: --get-comments) "
) ,
)
2021-05-20 15:40:35 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-comments " ,
" --no-get-comments " ,
action = " store_false " ,
dest = " getcomments " ,
help = " Do not retrieve video comments unless the extraction is known to be quick (Alias: --no-get-comments) " ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --load-info-json " ,
" --load-info " ,
dest = " load_info_filename " ,
metavar = " FILE " ,
help = ' JSON file containing the video information (created with the " --write-info-json " option) ' ,
)
2014-10-12 23:10:11 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --cookies " ,
dest = " cookiefile " ,
metavar = " FILE " ,
help = " Netscape formatted file to read cookies from and dump cookie jar in " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-cookies " ,
action = " store_const " ,
const = None ,
dest = " cookiefile " ,
metavar = " FILE " ,
help = " Do not read/dump cookies from/to file (default) " ,
)
2021-07-21 21:32:49 +01:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --cookies-from-browser " ,
dest = " cookiesfrombrowser " ,
metavar = " BROWSER[+KEYRING][:PROFILE][::CONTAINER] " ,
2021-07-21 21:32:49 +01:00
help = (
2023-03-18 16:59:11 +01:00
" The name of the browser to load cookies from. "
2021-12-27 01:28:44 +00:00
f ' Currently supported browsers are: { " , " . join ( sorted ( SUPPORTED_BROWSERS ) ) } . '
2023-03-18 16:59:11 +01:00
" Optionally, the KEYRING used for decrypting Chromium cookies on Linux, "
" the name/path of the PROFILE to load cookies from, "
2022-09-01 09:52:59 +00:00
' and the CONTAINER name (if Firefox) ( " none " for no container) '
2023-03-18 16:59:11 +01:00
" can be given with their respective seperators. "
" By default, all containers of the most recently accessed profile are used. "
f ' Currently supported keyrings are: { " , " . join ( map ( str . lower , sorted ( SUPPORTED_KEYRINGS ) ) ) } '
) ,
)
2021-07-21 21:32:49 +01:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-cookies-from-browser " ,
action = " store_const " ,
const = None ,
dest = " cookiesfrombrowser " ,
help = " Do not load cookies from browser (default) " ,
)
2014-09-13 07:55:21 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --cache-dir " ,
dest = " cachedir " ,
default = None ,
metavar = " DIR " ,
2022-10-04 15:23:11 +11:00
help = (
2023-03-18 16:59:11 +01:00
" Location in the filesystem where yt-dlp can store some downloaded information "
" (such as client ids and signatures) permanently. By default $ {XDG_CACHE_HOME} /yt-dlp "
) ,
)
2014-09-13 07:55:21 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --no-cache-dir " ,
action = " store_false " ,
dest = " cachedir " ,
help = " Disable filesystem caching " ,
)
2014-09-13 07:55:21 +02:00
filesystem . add_option (
2023-03-18 16:59:11 +01:00
" --rm-cache-dir " ,
action = " store_true " ,
dest = " rm_cachedir " ,
help = " Delete all filesystem cache files " ,
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
thumbnail = optparse . OptionGroup ( parser , " Thumbnail Options " )
2015-01-25 02:38:47 +01:00
thumbnail . add_option (
2023-03-18 16:59:11 +01:00
" --write-thumbnail " ,
action = " callback " ,
dest = " writethumbnail " ,
default = False ,
2021-12-06 23:26:34 +05:30
# Should override --no-write-thumbnail, but not --write-all-thumbnail
callback = lambda option , _ , __ , parser : setattr (
2023-03-18 16:59:11 +01:00
parser . values , option . dest , getattr ( parser . values , option . dest ) or True
) ,
help = " Write thumbnail image to disk " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
thumbnail . add_option (
2023-03-18 16:59:11 +01:00
" --no-write-thumbnail " ,
action = " store_false " ,
dest = " writethumbnail " ,
help = " Do not write thumbnail image to disk (default) " ,
)
2015-01-25 03:11:12 +01:00
thumbnail . add_option (
2023-03-18 16:59:11 +01:00
" --write-all-thumbnails " ,
action = " store_const " ,
dest = " writethumbnail " ,
const = " all " ,
help = " Write all thumbnail image formats to disk " ,
)
2015-01-25 02:38:47 +01:00
thumbnail . add_option (
2023-03-18 16:59:11 +01:00
" --list-thumbnails " ,
action = " store_true " ,
dest = " list_thumbnails " ,
default = False ,
help = " List available thumbnails of each video. Simulate unless --no-simulate is used " ,
)
2015-01-25 02:38:47 +01:00
2023-03-18 16:59:11 +01:00
link = optparse . OptionGroup ( parser , " Internet Shortcut Options " )
2020-10-27 16:07:21 +05:30
link . add_option (
2023-03-18 16:59:11 +01:00
" --write-link " ,
action = " store_true " ,
dest = " writelink " ,
default = False ,
help = " Write an internet shortcut file, depending on the current platform (.url, .webloc or .desktop). The URL may be cached by the OS " ,
)
2020-10-27 16:07:21 +05:30
link . add_option (
2023-03-18 16:59:11 +01:00
" --write-url-link " ,
action = " store_true " ,
dest = " writeurllink " ,
default = False ,
help = " Write a .url Windows internet shortcut. The OS caches the URL based on the file path " ,
)
2020-10-27 16:07:21 +05:30
link . add_option (
2023-03-18 16:59:11 +01:00
" --write-webloc-link " ,
action = " store_true " ,
dest = " writewebloclink " ,
default = False ,
help = " Write a .webloc macOS internet shortcut " ,
)
2020-10-27 16:07:21 +05:30
link . add_option (
2023-03-18 16:59:11 +01:00
" --write-desktop-link " ,
action = " store_true " ,
dest = " writedesktoplink " ,
default = False ,
help = " Write a .desktop Linux internet shortcut " ,
)
2020-10-27 16:07:21 +05:30
2023-03-18 16:59:11 +01:00
postproc = optparse . OptionGroup ( parser , " Post-Processing Options " )
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" -x " ,
" --extract-audio " ,
action = " store_true " ,
dest = " extractaudio " ,
default = False ,
help = " Convert video files to audio-only files (requires ffmpeg and ffprobe) " ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --audio-format " ,
metavar = " FORMAT " ,
dest = " audioformat " ,
default = " best " ,
2021-05-22 13:54:12 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Format to convert the audio to when -x is used. "
2022-07-31 02:15:22 +05:30
f ' (currently supported: best (default), { " , " . join ( sorted ( FFmpegExtractAudioPP . SUPPORTED_EXTS ) ) } ). '
2023-03-18 16:59:11 +01:00
" You can specify multiple rules using similar syntax as --remux-video "
) ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --audio-quality " ,
metavar = " QUALITY " ,
dest = " audioquality " ,
default = " 5 " ,
2022-06-06 21:49:57 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Specify ffmpeg audio quality to use when converting the audio with -x. "
" Insert a value between 0 (best) and 10 (worst) for VBR or a specific bitrate like 128K (default %d efault) "
) ,
)
2020-05-16 18:09:12 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --remux-video " ,
metavar = " FORMAT " ,
dest = " remuxvideo " ,
default = None ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Remux the video into another container if necessary "
2022-06-06 21:49:57 +05:30
f ' (currently supported: { " , " . join ( FFmpegVideoRemuxerPP . SUPPORTED_EXTS ) } ). '
2023-03-18 16:59:11 +01:00
" If target container does not support the video/audio codec, remuxing will fail. You can specify multiple rules; "
' e.g. " aac>m4a/mov>mp4/mkv " will remux aac to m4a, mov to mp4 and anything else to mkv '
) ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --recode-video " ,
metavar = " FORMAT " ,
dest = " recodevideo " ,
default = None ,
help = " Re-encode the video into another format if necessary. The syntax and supported formats are the same as --remux-video " ,
)
2015-06-09 22:08:16 -03:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --postprocessor-args " ,
" --ppa " ,
metavar = " NAME:ARGS " ,
dest = " postprocessor_args " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
Improve argument parsing for `-P`, `-o`, `-S`
* `-P "subtitle,thumbnail:PATH"` is now possible. Similarly for `-o`
* `-S "fps,br" -S "res,codec"` is now interpreted as `-S res,codec,fps,br`. Previously, `-S fps,br` was ignored in this case.
2021-04-10 20:30:38 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" allowed_keys " : r " \ w+(?: \ + \ w+)? " ,
" default_key " : " default-compat " ,
" process " : shlex . split ,
" multiple_keys " : False ,
} ,
help = (
" Give these arguments to the postprocessors. "
2021-01-20 21:37:40 +05:30
' Specify the postprocessor/executable name and the arguments separated by a colon " : " '
2023-03-18 16:59:11 +01:00
" to give the argument to the specified postprocessor/executable. Supported PP are: "
" Merger, ModifyChapters, SplitChapters, ExtractAudio, VideoRemuxer, VideoConvertor, "
" Metadata, EmbedSubtitle, EmbedThumbnail, SubtitlesConvertor, ThumbnailsConvertor, "
" FixupStretched, FixupM4a, FixupM3u8, FixupTimestamp and FixupDuration. "
" The supported executables are: AtomicParsley, FFmpeg and FFprobe. "
2021-01-20 21:37:40 +05:30
' You can also specify " PP+EXE:ARGS " to give the arguments to the specified executable '
2023-03-18 16:59:11 +01:00
" only when being used by the specified postprocessor. Additionally, for ffmpeg/ffprobe, "
2021-03-15 05:30:18 +05:30
' " _i " / " _o " can be appended to the prefix optionally followed by a number to pass the argument '
2022-08-14 21:04:13 +09:00
' before the specified input/output file, e.g. --ppa " Merger+ffmpeg_i1:-v quiet " . '
2023-03-18 16:59:11 +01:00
" You can use this option multiple times to give different arguments to different "
" postprocessors. (Alias: --ppa) "
) ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" -k " ,
" --keep-video " ,
action = " store_true " ,
dest = " keepvideo " ,
default = False ,
help = " Keep the intermediate video file on disk after post-processing " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-keep-video " ,
action = " store_false " ,
dest = " keepvideo " ,
help = " Delete the intermediate video file after post-processing (default) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --post-overwrites " ,
action = " store_false " ,
dest = " nopostoverwrites " ,
help = " Overwrite post-processed files (default) " ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-post-overwrites " ,
action = " store_true " ,
dest = " nopostoverwrites " ,
default = False ,
help = " Do not overwrite post-processed files " ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --embed-subs " ,
action = " store_true " ,
dest = " embedsubtitles " ,
default = False ,
help = " Embed subtitles in the video (only for mp4, webm and mkv videos) " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-embed-subs " ,
action = " store_false " ,
dest = " embedsubtitles " ,
help = " Do not embed subtitles (default) " ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --embed-thumbnail " ,
action = " store_true " ,
dest = " embedthumbnail " ,
default = False ,
help = " Embed thumbnail in the video as cover art " ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-embed-thumbnail " ,
action = " store_false " ,
dest = " embedthumbnail " ,
help = " Do not embed thumbnail (default) " ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --embed-metadata " ,
" --add-metadata " ,
action = " store_true " ,
dest = " addmetadata " ,
default = False ,
2021-11-15 04:03:41 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Embed metadata to the video file. Also embeds chapters/infojson if present "
" unless --no-embed-chapters/--no-embed-info-json are used (Alias: --add-metadata) "
) ,
)
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-embed-metadata " ,
" --no-add-metadata " ,
action = " store_false " ,
dest = " addmetadata " ,
help = " Do not add metadata to file (default) (Alias: --no-add-metadata) " ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --embed-chapters " ,
" --add-chapters " ,
action = " store_true " ,
dest = " addchapters " ,
default = None ,
help = " Add chapter markers to the video file (Alias: --add-chapters) " ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-embed-chapters " ,
" --no-add-chapters " ,
action = " store_false " ,
dest = " addchapters " ,
help = " Do not add chapter markers (default) (Alias: --no-add-chapters) " ,
)
2021-11-15 04:03:41 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --embed-info-json " ,
action = " store_true " ,
dest = " embed_infojson " ,
default = None ,
help = " Embed the infojson as an attachment to mkv/mka video files " ,
)
2021-11-15 04:03:41 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-embed-info-json " ,
action = " store_false " ,
dest = " embed_infojson " ,
help = " Do not embed the infojson as an attachment to the video file " ,
)
2015-03-04 22:33:56 +01:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --metadata-from-title " ,
metavar = " FORMAT " ,
dest = " metafromtitle " ,
help = optparse . SUPPRESS_HELP ,
)
2021-01-26 15:50:20 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --parse-metadata " ,
metavar = " [WHEN:]FROM:TO " ,
dest = " parse_metadata " ,
* * when_prefix ( " pre_process " ) ,
Added negative switches for many existing options
* The idea is that it should be possible to negate any boolean option by adding a `no-` to the switch
New: `--no-ignore-dynamic-mpd`, `--no-allow-dynamic-mpd`, `--allow-dynamic-mpd`, `--youtube-include-hls-manifest`, `--no-youtube-include-hls-manifest`, `--no-youtube-skip-hls-manifest`, `--no-download`, `--no-download-archive`, `--resize-buffer`, `--part`, `--mtime`, `--no-keep-fragments`, `--no-cookies`, `--no-write-annotations`, `--no-write-info-json`, `--no-write-description`, `--no-write-thumbnail`, `--youtube-include-dash-manifest`, `--post-overwrites`, `--no-keep-video`, `--no-embed-subs`, `--no-embed-thumbnail`, `--no-add-metadata`, `--no-include-ads`, `--no-write-sub`, `--no-write-auto-sub`, `--no-playlist-reverse`, `--no-restrict-filenames`, `--youtube-include-dash-manifest`, `--no-format-sort-force`, `--flat-videos`, `--no-list-formats-as-table`, `--no-sponskrub`, `--no-sponskrub-cut`, `--no-sponskrub-force`
Renamed: `--write-subs`, --no-write-subs`, `--no-write-auto-subs, `--write-auto-subs`. Note that these can still be used without the ending "s"
2021-01-04 23:15:15 +05:30
help = (
2022-12-30 11:01:14 +05:30
' Parse additional metadata like title/artist from other fields; see " MODIFYING METADATA " for details. '
2023-03-18 16:59:11 +01:00
' Supported values of " WHEN " are the same as that of --use-postprocessor (default: pre_process) '
) ,
)
2021-08-10 01:22:55 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --replace-in-metadata " ,
dest = " parse_metadata " ,
metavar = " [WHEN:]FIELDS REGEX REPLACE " ,
nargs = 3 ,
* * when_prefix ( " pre_process " ) ,
2022-12-30 11:01:14 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Replace text in a metadata field using the given regex. This option can be used multiple times. "
' Supported values of " WHEN " are the same as that of --use-postprocessor (default: pre_process) '
) ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --xattrs " ,
" --xattr " ,
action = " store_true " ,
dest = " xattrs " ,
default = False ,
help = " Write metadata to the video file ' s xattrs (using dublin core and xdg standards) " ,
)
2022-01-13 16:31:08 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --concat-playlist " ,
metavar = " POLICY " ,
dest = " concat_playlist " ,
default = " multi_video " ,
choices = ( " never " , " always " , " multi_video " ) ,
2022-01-13 16:31:08 +05:30
help = (
2022-01-20 04:27:07 +05:30
' Concatenate videos in a playlist. One of " never " , " always " , or '
' " multi_video " (default; only when the videos form a single show). '
2023-03-18 16:59:11 +01:00
" All the video files must have same codecs and number of streams to be concatable. "
2022-01-13 16:31:08 +05:30
' The " pl_video: " prefix can be used with " --paths " and " --output " to '
2023-03-18 16:59:11 +01:00
' set the output filename for the concatenated files. See " OUTPUT TEMPLATE " for details '
) ,
)
2015-01-10 05:45:51 +01:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --fixup " ,
metavar = " POLICY " ,
dest = " fixup " ,
default = None ,
choices = ( " never " , " ignore " , " warn " , " detect_or_warn " , " force " ) ,
help = (
" Automatically correct known faults of the file. "
" One of never (do nothing), warn (only emit a warning), "
" detect_or_warn (the default; fix file if we can, warn otherwise), "
" force (try fixing even if file already exists) "
) ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --prefer-avconv " ,
" --no-prefer-ffmpeg " ,
action = " store_false " ,
dest = " prefer_ffmpeg " ,
help = optparse . SUPPRESS_HELP ,
)
2014-10-12 23:10:11 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --prefer-ffmpeg " ,
" --no-prefer-avconv " ,
action = " store_true " ,
dest = " prefer_ffmpeg " ,
default = True ,
help = optparse . SUPPRESS_HELP ,
)
2015-02-13 11:14:01 +01:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --ffmpeg-location " ,
" --avconv-location " ,
metavar = " PATH " ,
dest = " ffmpeg_location " ,
help = " Location of the ffmpeg binary; either the path to the binary or its containing directory " ,
)
2014-09-13 07:55:21 +02:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --exec " ,
metavar = " [WHEN:]CMD " ,
dest = " exec_cmd " ,
* * when_prefix ( " after_move " ) ,
2022-12-30 11:15:41 +05:30
help = (
' Execute a command, optionally prefixed with when to execute it, separated by a " : " . '
' Supported values of " WHEN " are the same as that of --use-postprocessor (default: after_move). '
2023-03-18 16:59:11 +01:00
" Same syntax as the output template can be used to pass any field as arguments to the command. "
2022-01-03 16:43:54 +05:30
' After download, an additional field " filepath " that contains the final path of the downloaded file '
2023-03-18 16:59:11 +01:00
" is also available, and if no fields are passed, % (filepath,_filename|)q is appended to the end of the command. "
" This option can be used multiple times "
) ,
)
2021-08-07 13:30:55 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-exec " ,
action = " store_const " ,
dest = " exec_cmd " ,
const = { } ,
help = " Remove any previously defined --exec " ,
)
2021-08-07 13:30:55 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --exec-before-download " ,
metavar = " CMD " ,
action = " append " ,
dest = " exec_before_dl_cmd " ,
help = optparse . SUPPRESS_HELP ,
)
2021-07-19 23:26:22 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-exec-before-download " ,
action = " store_const " ,
dest = " exec_before_dl_cmd " ,
const = None ,
help = optparse . SUPPRESS_HELP ,
)
2015-02-28 14:43:24 +01:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --convert-subs " ,
" --convert-sub " ,
" --convert-subtitles " ,
metavar = " FORMAT " ,
dest = " convertsubtitles " ,
default = None ,
2021-05-22 13:54:12 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Convert the subtitles to another format (currently supported: %s ) "
" (Alias: --convert-subtitles) "
% " , " . join ( sorted ( FFmpegSubtitlesConvertorPP . SUPPORTED_EXTS ) )
) ,
)
2021-04-11 03:48:52 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --convert-thumbnails " ,
metavar = " FORMAT " ,
dest = " convertthumbnails " ,
default = None ,
2021-05-22 13:54:12 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Convert the thumbnails to another format "
2022-07-31 02:15:22 +05:30
f ' (currently supported: { " , " . join ( sorted ( FFmpegThumbnailsConvertorPP . SUPPORTED_EXTS ) ) } ). '
2023-03-18 16:59:11 +01:00
" You can specify multiple rules using similar syntax as --remux-video "
) ,
)
2021-03-15 04:32:13 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --split-chapters " ,
" --split-tracks " ,
dest = " split_chapters " ,
action = " store_true " ,
default = False ,
2021-03-15 04:32:13 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Split video into multiple files based on internal chapters. "
2021-03-15 04:32:13 +05:30
' The " chapter: " prefix can be used with " --paths " and " --output " to '
2023-03-18 16:59:11 +01:00
' set the output filename for the split files. See " OUTPUT TEMPLATE " for details '
) ,
)
2021-03-15 04:32:13 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-split-chapters " ,
" --no-split-tracks " ,
dest = " split_chapters " ,
action = " store_false " ,
help = " Do not split video based on chapters (default) " ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --remove-chapters " ,
metavar = " REGEX " ,
dest = " remove_chapters " ,
action = " append " ,
2021-10-18 16:03:05 +05:30
help = (
2023-03-18 16:59:11 +01:00
" Remove chapters whose title matches the given regular expression. "
" The syntax is the same as --download-sections. This option can be used multiple times "
) ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-remove-chapters " ,
dest = " remove_chapters " ,
action = " store_const " ,
const = None ,
help = " Do not remove any chapters from the file (default) " ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --force-keyframes-at-cuts " ,
action = " store_true " ,
dest = " force_keyframes_at_cuts " ,
default = False ,
2021-09-01 20:55:16 +00:00
help = (
2023-03-18 16:59:11 +01:00
" Force keyframes at cuts when downloading/splitting/removing sections. "
" This is slow due to needing a re-encode, but the resulting video may have fewer artifacts around the cuts "
) ,
)
2021-09-01 20:55:16 +00:00
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --no-force-keyframes-at-cuts " ,
action = " store_false " ,
dest = " force_keyframes_at_cuts " ,
help = " Do not force keyframes around the chapters when cutting/splitting (default) " ,
)
_postprocessor_opts_parser = lambda key , val = " " : (
* ( item . split ( " = " , 1 ) for item in ( val . split ( " ; " ) if val else [ ] ) ) ,
( " key " , remove_end ( key , " PP " ) ) ,
)
2021-09-30 02:23:33 +05:30
postproc . add_option (
2023-03-18 16:59:11 +01:00
" --use-postprocessor " ,
metavar = " NAME[:ARGS] " ,
dest = " add_postprocessors " ,
default = [ ] ,
type = " str " ,
action = " callback " ,
callback = _list_from_options_callback ,
2021-09-30 02:23:33 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" delim " : None ,
" process " : lambda val : dict ( _postprocessor_opts_parser ( * val . split ( " : " , 1 ) ) ) ,
} ,
help = (
" The (case sensitive) name of plugin postprocessors to be enabled, "
2021-12-19 10:18:06 -05:00
' and (optionally) arguments to be passed to it, separated by a colon " : " . '
2021-09-30 02:23:33 +05:30
' ARGS are a semicolon " ; " delimited list of NAME=VALUE. '
' The " when " argument determines when the postprocessor is invoked. '
2022-02-22 17:13:30 +05:30
' It can be one of " pre_process " (after video extraction), " after_filter " (after video passes filter), '
2022-12-30 11:15:41 +05:30
' " video " (after --format; before --print/--output), " before_dl " (before each video download), '
' " post_process " (after each video download; default), '
2022-02-22 17:13:30 +05:30
' " after_move " (after moving video file to it \' s final locations), '
2022-01-02 16:23:20 +05:30
' " after_video " (after downloading and processing all formats of a video), '
2022-02-22 17:13:30 +05:30
' or " playlist " (at end of playlist). '
2023-03-18 16:59:11 +01:00
" This option can be used multiple times to add different postprocessors "
) ,
)
2014-09-13 07:55:21 +02:00
2023-03-18 16:59:11 +01:00
sponsorblock = optparse . OptionGroup (
parser ,
" SponsorBlock Options " ,
description = (
" Make chapter entries for, or remove various segments (sponsor, introductions, etc.) "
" from downloaded YouTube videos using the SponsorBlock API (https://sponsor.ajay.app) "
) ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponsorblock-mark " ,
metavar = " CATS " ,
dest = " sponsorblock_mark " ,
default = set ( ) ,
action = " callback " ,
type = " str " ,
callback = _set_from_options_callback ,
callback_kwargs = {
" allowed_values " : SponsorBlockPP . CATEGORIES . keys ( ) ,
" aliases " : { " default " : [ " all " ] } ,
} ,
help = (
" SponsorBlock categories to create chapters for, separated by commas. "
2022-05-19 20:05:17 +05:30
f ' Available categories are { " , " . join ( SponsorBlockPP . CATEGORIES . keys ( ) ) } , all and default (=all). '
' You can prefix the category with a " - " to exclude it. See [1] for description of the categories. '
2023-03-18 16:59:11 +01:00
" E.g. --sponsorblock-mark all,-preview [1] https://wiki.sponsor.ajay.app/w/Segment_Categories "
) ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponsorblock-remove " ,
metavar = " CATS " ,
dest = " sponsorblock_remove " ,
default = set ( ) ,
action = " callback " ,
type = " str " ,
callback = _set_from_options_callback ,
callback_kwargs = {
" allowed_values " : set ( SponsorBlockPP . CATEGORIES . keys ( ) )
- set ( SponsorBlockPP . NON_SKIPPABLE_CATEGORIES . keys ( ) ) ,
2021-12-09 12:40:31 +00:00
# Note: From https://wiki.sponsor.ajay.app/w/Types:
# The filler category is very aggressive.
# It is strongly recommended to not use this in a client by default.
2023-03-18 16:59:11 +01:00
" aliases " : { " default " : [ " all " , " -filler " ] } ,
} ,
help = (
" SponsorBlock categories to be removed from the video file, separated by commas. "
" If a category is present in both mark and remove, remove takes precedence. "
" The syntax and available categories are the same as for --sponsorblock-mark "
2021-12-09 12:40:31 +00:00
' except that " default " refers to " all,-filler " '
2023-03-18 16:59:11 +01:00
f ' and { " , " . join ( SponsorBlockPP . NON_SKIPPABLE_CATEGORIES . keys ( ) ) } are not available '
) ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponsorblock-chapter-title " ,
metavar = " TEMPLATE " ,
default = DEFAULT_SPONSORBLOCK_CHAPTER_TITLE ,
dest = " sponsorblock_chapter_title " ,
2021-09-01 20:55:16 +00:00
help = (
2023-03-18 16:59:11 +01:00
" An output template for the title of the SponsorBlock chapters created by --sponsorblock-mark. "
" The only available fields are start_time, end_time, category, categories, name, category_names. "
' Defaults to " %d efault " '
) ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --no-sponsorblock " ,
default = False ,
action = " store_true " ,
dest = " no_sponsorblock " ,
help = " Disable both --sponsorblock-mark and --sponsorblock-remove " ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponsorblock-api " ,
metavar = " URL " ,
default = " https://sponsor.ajay.app " ,
dest = " sponsorblock_api " ,
help = " SponsorBlock API location, defaults to %d efault " ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponskrub " ,
action = " store_true " ,
dest = " sponskrub " ,
default = False ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --no-sponskrub " ,
action = " store_false " ,
dest = " sponskrub " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponskrub-cut " ,
default = False ,
action = " store_true " ,
dest = " sponskrub_cut " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --no-sponskrub-cut " ,
action = " store_false " ,
dest = " sponskrub_cut " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponskrub-force " ,
default = False ,
action = " store_true " ,
dest = " sponskrub_force " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --no-sponskrub-force " ,
action = " store_true " ,
dest = " sponskrub_force " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponskrub-location " ,
metavar = " PATH " ,
dest = " sponskrub_path " ,
default = " " ,
help = optparse . SUPPRESS_HELP ,
)
2021-09-01 20:55:16 +00:00
sponsorblock . add_option (
2023-03-18 16:59:11 +01:00
" --sponskrub-args " ,
dest = " sponskrub_args " ,
metavar = " ARGS " ,
help = optparse . SUPPRESS_HELP ,
)
2020-11-15 05:58:41 +05:30
2023-03-18 16:59:11 +01:00
extractor = optparse . OptionGroup ( parser , " Extractor Options " )
2021-03-01 05:18:37 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --extractor-retries " ,
dest = " extractor_retries " ,
metavar = " RETRIES " ,
default = 3 ,
help = ' Number of retries for known extractor errors (default is %d efault), or " infinite " ' ,
)
2020-09-16 13:00:41 +02:00
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --allow-dynamic-mpd " ,
" --no-ignore-dynamic-mpd " ,
action = " store_true " ,
dest = " dynamic_mpd " ,
default = True ,
help = " Process dynamic DASH manifests (default) (Alias: --no-ignore-dynamic-mpd) " ,
)
2020-09-16 13:00:41 +02:00
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --ignore-dynamic-mpd " ,
" --no-allow-dynamic-mpd " ,
action = " store_false " ,
dest = " dynamic_mpd " ,
help = " Do not process dynamic DASH manifests (Alias: --no-allow-dynamic-mpd) " ,
)
2021-02-24 09:47:53 -05:00
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --hls-split-discontinuity " ,
dest = " hls_split_discontinuity " ,
action = " store_true " ,
default = False ,
help = " Split HLS playlists to different formats at discontinuities such as ad breaks " ,
2021-02-24 09:47:53 -05:00
)
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --no-hls-split-discontinuity " ,
dest = " hls_split_discontinuity " ,
action = " store_false " ,
help = " Do not split HLS playlists to different formats at discontinuities such as ad breaks (default) " ,
)
_extractor_arg_parser = lambda key , vals = " " : (
key . strip ( ) . lower ( ) . replace ( " - " , " _ " ) ,
[ val . replace ( r " \ , " , " , " ) . strip ( ) for val in re . split ( r " (?<! \\ ), " , vals ) ] ,
)
2021-06-25 19:35:41 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --extractor-args " ,
metavar = " IE_KEY:ARGS " ,
dest = " extractor_args " ,
default = { } ,
type = " str " ,
action = " callback " ,
callback = _dict_from_options_callback ,
2021-06-25 19:35:41 +05:30
callback_kwargs = {
2023-03-18 16:59:11 +01:00
" multiple_keys " : False ,
" process " : lambda val : dict (
_extractor_arg_parser ( * arg . split ( " = " , 1 ) ) for arg in val . split ( " ; " )
) ,
} ,
help = (
2022-09-22 01:37:44 +05:30
' Pass ARGS arguments to the IE_KEY extractor. See " EXTRACTOR ARGUMENTS " for details. '
2023-03-18 16:59:11 +01:00
" You can use this option multiple times to give arguments for different extractors "
) ,
)
2021-02-24 21:31:01 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --youtube-include-dash-manifest " ,
" --no-youtube-skip-dash-manifest " ,
action = " store_true " ,
dest = " youtube_include_dash_manifest " ,
default = True ,
help = optparse . SUPPRESS_HELP ,
)
2021-02-24 21:31:01 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --youtube-skip-dash-manifest " ,
" --no-youtube-include-dash-manifest " ,
action = " store_false " ,
dest = " youtube_include_dash_manifest " ,
help = optparse . SUPPRESS_HELP ,
)
2021-02-24 21:31:01 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --youtube-include-hls-manifest " ,
" --no-youtube-skip-hls-manifest " ,
action = " store_true " ,
dest = " youtube_include_hls_manifest " ,
default = True ,
help = optparse . SUPPRESS_HELP ,
)
2021-02-24 21:31:01 +05:30
extractor . add_option (
2023-03-18 16:59:11 +01:00
" --youtube-skip-hls-manifest " ,
" --no-youtube-include-hls-manifest " ,
action = " store_false " ,
dest = " youtube_include_hls_manifest " ,
help = optparse . SUPPRESS_HELP ,
)
2020-09-16 13:00:41 +02:00
2014-09-13 07:55:21 +02:00
parser . add_option_group ( general )
2015-01-10 19:55:36 +01:00
parser . add_option_group ( network )
2017-02-19 03:58:17 +07:00
parser . add_option_group ( geo )
2014-09-13 07:55:21 +02:00
parser . add_option_group ( selection )
parser . add_option_group ( downloader )
parser . add_option_group ( filesystem )
2015-01-25 02:38:47 +01:00
parser . add_option_group ( thumbnail )
2020-10-27 16:07:21 +05:30
parser . add_option_group ( link )
2014-09-13 07:55:21 +02:00
parser . add_option_group ( verbosity )
parser . add_option_group ( workarounds )
parser . add_option_group ( video_format )
parser . add_option_group ( subtitles )
parser . add_option_group ( authentication )
parser . add_option_group ( postproc )
2021-09-01 20:55:16 +00:00
parser . add_option_group ( sponsorblock )
2020-09-16 13:00:41 +02:00
parser . add_option_group ( extractor )
2014-09-13 07:55:21 +02:00
2021-12-14 22:33:47 +05:30
return parser
2021-09-13 08:22:11 +05:30
2016-09-14 17:28:17 +02:00
2021-12-14 22:33:47 +05:30
def _hide_login_info ( opts ) :
2023-03-18 16:59:11 +01:00
deprecation_warning (
f ' " { __name__ } ._hide_login_info " is deprecated and may be removed '
' in a future version. Use " yt_dlp.utils.Config.hide_login_info " instead '
)
2021-12-14 22:33:47 +05:30
return Config . hide_login_info ( opts )