Add bestvideo and worstvideo to special format names (#2163)
This commit is contained in:
		
							parent
							
								
									aba77bbfc2
								
							
						
					
					
						commit
						bc6d597828
					
				| @ -182,6 +182,24 @@ class TestFormatSelection(unittest.TestCase): | |||||||
|         downloaded = ydl.downloaded_info_dicts[0] |         downloaded = ydl.downloaded_info_dicts[0] | ||||||
|         self.assertEqual(downloaded['format_id'], 'vid-high') |         self.assertEqual(downloaded['format_id'], 'vid-high') | ||||||
| 
 | 
 | ||||||
|  |     def test_format_selection_video(self): | ||||||
|  |         formats = [ | ||||||
|  |             {'format_id': 'dash-video-low', 'ext': 'mp4', 'preference': 1, 'acodec': 'none'}, | ||||||
|  |             {'format_id': 'dash-video-high', 'ext': 'mp4', 'preference': 2, 'acodec': 'none'}, | ||||||
|  |             {'format_id': 'vid', 'ext': 'mp4', 'preference': 3}, | ||||||
|  |         ] | ||||||
|  |         info_dict = {'formats': formats, 'extractor': 'test'} | ||||||
|  | 
 | ||||||
|  |         ydl = YDL({'format': 'bestvideo'}) | ||||||
|  |         ydl.process_ie_result(info_dict.copy()) | ||||||
|  |         downloaded = ydl.downloaded_info_dicts[0] | ||||||
|  |         self.assertEqual(downloaded['format_id'], 'dash-video-high') | ||||||
|  | 
 | ||||||
|  |         ydl = YDL({'format': 'worstvideo'}) | ||||||
|  |         ydl.process_ie_result(info_dict.copy()) | ||||||
|  |         downloaded = ydl.downloaded_info_dicts[0] | ||||||
|  |         self.assertEqual(downloaded['format_id'], 'dash-video-low') | ||||||
|  | 
 | ||||||
|     def test_youtube_format_selection(self): |     def test_youtube_format_selection(self): | ||||||
|         order = [ |         order = [ | ||||||
|             '38', '37', '46', '22', '45', '35', '44', '18', '34', '43', '6', '5', '36', '17', '13', |             '38', '37', '46', '22', '45', '35', '44', '18', '34', '43', '6', '5', '36', '17', '13', | ||||||
|  | |||||||
| @ -667,6 +667,18 @@ class YoutubeDL(object): | |||||||
|                 if f.get('vcodec') == 'none'] |                 if f.get('vcodec') == 'none'] | ||||||
|             if audio_formats: |             if audio_formats: | ||||||
|                 return audio_formats[0] |                 return audio_formats[0] | ||||||
|  |         elif format_spec == 'bestvideo': | ||||||
|  |             video_formats = [ | ||||||
|  |                 f for f in available_formats | ||||||
|  |                 if f.get('acodec') == 'none'] | ||||||
|  |             if video_formats: | ||||||
|  |                 return video_formats[-1] | ||||||
|  |         elif format_spec == 'worstvideo': | ||||||
|  |             video_formats = [ | ||||||
|  |                 f for f in available_formats | ||||||
|  |                 if f.get('acodec') == 'none'] | ||||||
|  |             if video_formats: | ||||||
|  |                 return video_formats[0] | ||||||
|         else: |         else: | ||||||
|             extensions = ['mp4', 'flv', 'webm', '3gp'] |             extensions = ['mp4', 'flv', 'webm', '3gp'] | ||||||
|             if format_spec in extensions: |             if format_spec in extensions: | ||||||
|  | |||||||
| @ -316,7 +316,7 @@ def parseOpts(overrideArguments=None): | |||||||
| 
 | 
 | ||||||
|     video_format.add_option('-f', '--format', |     video_format.add_option('-f', '--format', | ||||||
|             action='store', dest='format', metavar='FORMAT', default=None, |             action='store', dest='format', metavar='FORMAT', default=None, | ||||||
|             help='video format code, specify the order of preference using slashes: "-f 22/17/18". "-f mp4" and "-f flv" are also supported. You can also use the special names "best", "bestaudio", "worst", and "worstaudio". By default, youtube-dl will pick the best quality.') |             help='video format code, specify the order of preference using slashes: "-f 22/17/18". "-f mp4" and "-f flv" are also supported. You can also use the special names "best", "bestvideo", "bestaudio", "worst", "worstvideo" and "worstaudio". By default, youtube-dl will pick the best quality.') | ||||||
|     video_format.add_option('--all-formats', |     video_format.add_option('--all-formats', | ||||||
|             action='store_const', dest='format', help='download all available video formats', const='all') |             action='store_const', dest='format', help='download all available video formats', const='all') | ||||||
|     video_format.add_option('--prefer-free-formats', |     video_format.add_option('--prefer-free-formats', | ||||||
|  | |||||||
| @ -194,14 +194,14 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor): | |||||||
|         '151': {'ext': 'mp4', 'height': 72, 'resolution': '72p', 'format_note': 'HLS', 'preference': -10}, |         '151': {'ext': 'mp4', 'height': 72, 'resolution': '72p', 'format_note': 'HLS', 'preference': -10}, | ||||||
| 
 | 
 | ||||||
|         # DASH mp4 video |         # DASH mp4 video | ||||||
|         '133': {'ext': 'mp4', 'height': 240, 'resolution': '240p', 'format_note': 'DASH video', 'preference': -40}, |         '133': {'ext': 'mp4', 'height': 240, 'resolution': '240p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '134': {'ext': 'mp4', 'height': 360, 'resolution': '360p', 'format_note': 'DASH video', 'preference': -40}, |         '134': {'ext': 'mp4', 'height': 360, 'resolution': '360p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '135': {'ext': 'mp4', 'height': 480, 'resolution': '480p', 'format_note': 'DASH video', 'preference': -40}, |         '135': {'ext': 'mp4', 'height': 480, 'resolution': '480p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '136': {'ext': 'mp4', 'height': 720, 'resolution': '720p', 'format_note': 'DASH video', 'preference': -40}, |         '136': {'ext': 'mp4', 'height': 720, 'resolution': '720p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '137': {'ext': 'mp4', 'height': 1080, 'resolution': '1080p', 'format_note': 'DASH video', 'preference': -40}, |         '137': {'ext': 'mp4', 'height': 1080, 'resolution': '1080p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '138': {'ext': 'mp4', 'height': 2160, 'resolution': '2160p', 'format_note': 'DASH video', 'preference': -40}, |         '138': {'ext': 'mp4', 'height': 2160, 'resolution': '2160p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '160': {'ext': 'mp4', 'height': 192, 'resolution': '192p', 'format_note': 'DASH video', 'preference': -40}, |         '160': {'ext': 'mp4', 'height': 192, 'resolution': '192p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '264': {'ext': 'mp4', 'height': 1440, 'resolution': '1440p', 'format_note': 'DASH video', 'preference': -40}, |         '264': {'ext': 'mp4', 'height': 1440, 'resolution': '1440p', 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
| 
 | 
 | ||||||
|         # Dash mp4 audio |         # Dash mp4 audio | ||||||
|         '139': {'ext': 'm4a', 'format_note': 'DASH audio', 'vcodec': 'none', 'abr': 48, 'preference': -50}, |         '139': {'ext': 'm4a', 'format_note': 'DASH audio', 'vcodec': 'none', 'abr': 48, 'preference': -50}, | ||||||
| @ -209,12 +209,12 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor): | |||||||
|         '141': {'ext': 'm4a', 'format_note': 'DASH audio', 'vcodec': 'none', 'abr': 256, 'preference': -50}, |         '141': {'ext': 'm4a', 'format_note': 'DASH audio', 'vcodec': 'none', 'abr': 256, 'preference': -50}, | ||||||
| 
 | 
 | ||||||
|         # Dash webm |         # Dash webm | ||||||
|         '167': {'ext': 'webm', 'height': 360, 'width': 640, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '167': {'ext': 'webm', 'height': 360, 'width': 640, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '168': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '168': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '169': {'ext': 'webm', 'height': 720, 'width': 1280, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '169': {'ext': 'webm', 'height': 720, 'width': 1280, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '170': {'ext': 'webm', 'height': 1080, 'width': 1920, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '170': {'ext': 'webm', 'height': 1080, 'width': 1920, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '218': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '218': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '219': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, |         '219': {'ext': 'webm', 'height': 480, 'width': 854, 'format_note': 'DASH video', 'acodec': 'none', 'container': 'webm', 'vcodec': 'VP8', 'acodec': 'none', 'preference': -40}, | ||||||
|         '242': {'ext': 'webm', 'height': 240, 'resolution': '240p', 'format_note': 'DASH webm', 'preference': -40}, |         '242': {'ext': 'webm', 'height': 240, 'resolution': '240p', 'format_note': 'DASH webm', 'preference': -40}, | ||||||
|         '243': {'ext': 'webm', 'height': 360, 'resolution': '360p', 'format_note': 'DASH webm', 'preference': -40}, |         '243': {'ext': 'webm', 'height': 360, 'resolution': '360p', 'format_note': 'DASH webm', 'preference': -40}, | ||||||
|         '244': {'ext': 'webm', 'height': 480, 'resolution': '480p', 'format_note': 'DASH webm', 'preference': -40}, |         '244': {'ext': 'webm', 'height': 480, 'resolution': '480p', 'format_note': 'DASH webm', 'preference': -40}, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user