|
|
@ -1534,29 +1534,18 @@ class YoutubeDL(object): |
|
|
|
return res |
|
|
|
|
|
|
|
def list_formats(self, info_dict): |
|
|
|
def line(format, idlen=20): |
|
|
|
return (('%-' + compat_str(idlen + 1) + 's%-10s%-12s%s') % ( |
|
|
|
format['format_id'], |
|
|
|
format['ext'], |
|
|
|
self.format_resolution(format), |
|
|
|
self._format_note(format), |
|
|
|
)) |
|
|
|
|
|
|
|
formats = info_dict.get('formats', [info_dict]) |
|
|
|
idlen = max(len('format code'), |
|
|
|
max(len(f['format_id']) for f in formats)) |
|
|
|
formats_s = [ |
|
|
|
line(f, idlen) for f in formats |
|
|
|
table = [ |
|
|
|
[f['format_id'], f['ext'], self.format_resolution(f), self._format_note(f)] |
|
|
|
for f in formats |
|
|
|
if f.get('preference') is None or f['preference'] >= -1000] |
|
|
|
if len(formats) > 1: |
|
|
|
formats_s[-1] += (' ' if self._format_note(formats[-1]) else '') + '(best)' |
|
|
|
table[-1][-1] += (' ' if table[-1][-1] else '') + '(best)' |
|
|
|
|
|
|
|
header_line = line({ |
|
|
|
'format_id': 'format code', 'ext': 'extension', |
|
|
|
'resolution': 'resolution', 'format_note': 'note'}, idlen=idlen) |
|
|
|
header_line = ['format code', 'extension', 'resolution', 'note'] |
|
|
|
self.to_screen( |
|
|
|
'[info] Available formats for %s:\n%s\n%s' % |
|
|
|
(info_dict['id'], header_line, '\n'.join(formats_s))) |
|
|
|
'[info] Available formats for %s:\n%s' % |
|
|
|
(info_dict['id'], render_table(header_line, table))) |
|
|
|
|
|
|
|
def list_thumbnails(self, info_dict): |
|
|
|
thumbnails = info_dict.get('thumbnails') |
|
|
|