mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 14:45:14 +00:00 
			
		
		
		
	[phoenix] Add new extractor (Fixes #4036)
This commit is contained in:
		| @@ -280,6 +280,7 @@ from .orf import ( | |||||||
| from .parliamentliveuk import ParliamentLiveUKIE | from .parliamentliveuk import ParliamentLiveUKIE | ||||||
| from .patreon import PatreonIE | from .patreon import PatreonIE | ||||||
| from .pbs import PBSIE | from .pbs import PBSIE | ||||||
|  | from .phoenix import PhoenixIE | ||||||
| from .photobucket import PhotobucketIE | from .photobucket import PhotobucketIE | ||||||
| from .planetaplay import PlanetaPlayIE | from .planetaplay import PlanetaPlayIE | ||||||
| from .played import PlayedIE | from .played import PlayedIE | ||||||
|   | |||||||
							
								
								
									
										31
									
								
								youtube_dl/extractor/phoenix.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								youtube_dl/extractor/phoenix.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | from __future__ import unicode_literals | ||||||
|  |  | ||||||
|  | from .common import InfoExtractor | ||||||
|  | from .zdf import extract_from_xml_url | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class PhoenixIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'https?://(?:www\.)?phoenix\.de/content/(?P<id>[0-9]+)' | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'http://www.phoenix.de/content/884301', | ||||||
|  |         'md5': 'ed249f045256150c92e72dbb70eadec6', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '884301', | ||||||
|  |             'ext': 'mp4', | ||||||
|  |             'title': 'Michael Krons mit Hans-Werner Sinn', | ||||||
|  |             'description': 'Im Dialog - Sa. 25.10.14, 00.00 - 00.35 Uhr', | ||||||
|  |             'upload_date': '20141025', | ||||||
|  |             'uploader': 'Im Dialog', | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         video_id = self._match_id(url) | ||||||
|  |         webpage = self._download_webpage(url, video_id) | ||||||
|  |  | ||||||
|  |         internal_id = self._search_regex( | ||||||
|  |             r'<div class="phx_vod" id="phx_vod_([0-9]+)"', | ||||||
|  |             webpage, 'internal video ID') | ||||||
|  |  | ||||||
|  |         api_url = 'http://www.phoenix.de/php/zdfplayer-v1.3/data/beitragsDetails.php?ak=web&id=%s' % internal_id | ||||||
|  |         return extract_from_xml_url(self, video_id, api_url) | ||||||
| @@ -10,29 +10,8 @@ from ..utils import ( | |||||||
| ) | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| class ZDFIE(InfoExtractor): | def extract_from_xml_url(ie, video_id, xml_url): | ||||||
|     _VALID_URL = r'^https?://www\.zdf\.de/ZDFmediathek(?P<hash>#)?/(.*beitrag/(?:video/)?)(?P<id>[0-9]+)(?:/[^/?]+)?(?:\?.*)?' |     doc = ie._download_xml( | ||||||
|  |  | ||||||
|     _TEST = { |  | ||||||
|         'url': 'http://www.zdf.de/ZDFmediathek/beitrag/video/2037704/ZDFspezial---Ende-des-Machtpokers--?bc=sts;stt', |  | ||||||
|         'info_dict': { |  | ||||||
|             'id': '2037704', |  | ||||||
|             'ext': 'webm', |  | ||||||
|             'title': 'ZDFspezial - Ende des Machtpokers', |  | ||||||
|             'description': 'Union und SPD haben sich auf einen Koalitionsvertrag geeinigt. Aber was bedeutet das für die Bürger? Sehen Sie hierzu das ZDFspezial "Ende des Machtpokers - Große Koalition für Deutschland".', |  | ||||||
|             'duration': 1022, |  | ||||||
|             'uploader': 'spezial', |  | ||||||
|             'uploader_id': '225948', |  | ||||||
|             'upload_date': '20131127', |  | ||||||
|         }, |  | ||||||
|         'skip': 'Videos on ZDF.de are depublicised in short order', |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     def _real_extract(self, url): |  | ||||||
|         video_id = self._match_id(url) |  | ||||||
|  |  | ||||||
|         xml_url = 'http://www.zdf.de/ZDFmediathek/xmlservice/web/beitragsDetails?ak=web&id=%s' % video_id |  | ||||||
|         doc = self._download_xml( |  | ||||||
|         xml_url, video_id, |         xml_url, video_id, | ||||||
|         note='Downloading video info', |         note='Downloading video info', | ||||||
|         errnote='Failed to download video info') |         errnote='Failed to download video info') | ||||||
| @@ -93,8 +72,7 @@ class ZDFIE(InfoExtractor): | |||||||
|     formats = list(filter( |     formats = list(filter( | ||||||
|         lambda f: f['_available'], |         lambda f: f['_available'], | ||||||
|         map(xml_to_format, format_nodes))) |         map(xml_to_format, format_nodes))) | ||||||
|  |     ie._sort_formats(formats) | ||||||
|         self._sort_formats(formats) |  | ||||||
|  |  | ||||||
|     return { |     return { | ||||||
|         'id': video_id, |         'id': video_id, | ||||||
| @@ -106,3 +84,28 @@ class ZDFIE(InfoExtractor): | |||||||
|         'upload_date': upload_date, |         'upload_date': upload_date, | ||||||
|         'formats': formats, |         'formats': formats, | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class ZDFIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'^https?://www\.zdf\.de/ZDFmediathek(?P<hash>#)?/(.*beitrag/(?:video/)?)(?P<id>[0-9]+)(?:/[^/?]+)?(?:\?.*)?' | ||||||
|  |  | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'http://www.zdf.de/ZDFmediathek/beitrag/video/2037704/ZDFspezial---Ende-des-Machtpokers--?bc=sts;stt', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '2037704', | ||||||
|  |             'ext': 'webm', | ||||||
|  |             'title': 'ZDFspezial - Ende des Machtpokers', | ||||||
|  |             'description': 'Union und SPD haben sich auf einen Koalitionsvertrag geeinigt. Aber was bedeutet das für die Bürger? Sehen Sie hierzu das ZDFspezial "Ende des Machtpokers - Große Koalition für Deutschland".', | ||||||
|  |             'duration': 1022, | ||||||
|  |             'uploader': 'spezial', | ||||||
|  |             'uploader_id': '225948', | ||||||
|  |             'upload_date': '20131127', | ||||||
|  |         }, | ||||||
|  |         'skip': 'Videos on ZDF.de are depublicised in short order', | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         video_id = self._match_id(url) | ||||||
|  |  | ||||||
|  |         xml_url = 'http://www.zdf.de/ZDFmediathek/xmlservice/web/beitragsDetails?ak=web&id=%s' % video_id | ||||||
|  |         return extract_from_xml_url(self, video_id, xml_url) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Philipp Hagemeister
					Philipp Hagemeister