diff options
author | remitamine <[email protected]> | 2015-12-11 00:08:54 +0100 |
---|---|---|
committer | remitamine <[email protected]> | 2015-12-11 00:08:54 +0100 |
commit | e3e166d8cfa2be039b320d0c733b8233e95d3dcf (patch) | |
tree | b2fb99be150cbe9642b439af8ed7ec0f34df5301 | |
parent | db8e38b8cff2e67a9ff51104c4a7b33c20650204 (diff) | |
download | youtube-dl-e3e166d8cfa2be039b320d0c733b8233e95d3dcf.tar.gz youtube-dl-e3e166d8cfa2be039b320d0c733b8233e95d3dcf.zip |
[ign] improve extraction and extract uploader_id
-rw-r--r-- | youtube_dl/extractor/ign.py | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/youtube_dl/extractor/ign.py b/youtube_dl/extractor/ign.py index fb2753738..6160f03d1 100644 --- a/youtube_dl/extractor/ign.py +++ b/youtube_dl/extractor/ign.py @@ -32,6 +32,7 @@ class IGNIE(InfoExtractor): 'description': 'md5:c8946d4260a4d43a00d5ae8ed998870c', 'timestamp': 1370440800, 'upload_date': '20130605', + 'uploader_id': '[email protected]', } }, { @@ -48,6 +49,7 @@ class IGNIE(InfoExtractor): 'description': 'Rockstar drops the mic on this generation of games. Watch our review of the masterly Grand Theft Auto V.', 'timestamp': 1379339880, 'upload_date': '20130916', + 'uploader_id': '[email protected]', }, }, { @@ -58,6 +60,7 @@ class IGNIE(InfoExtractor): 'description': 'The twisted beauty of GTA 5 in stunning slow motion.', 'timestamp': 1386878820, 'upload_date': '20131212', + 'uploader_id': '[email protected]', }, }, ], @@ -75,6 +78,7 @@ class IGNIE(InfoExtractor): 'description': 'Brian and Jared explore Michel Ancel\'s captivating new preview.', 'timestamp': 1408047180, 'upload_date': '20140814', + 'uploader_id': '[email protected]', }, }, { @@ -104,8 +108,8 @@ class IGNIE(InfoExtractor): webpage = self._download_webpage(url, name_or_id) if page_type != 'video': multiple_urls = re.findall( - '<param name="flashvars"[^>]*value="[^"]*?url=(https?://www\.ign\.com/videos/.*?)["&]', - webpage) + r'<param name="flashvars"[^>]*value="[^"]*?url=(https?://www\.ign\.com/videos/.*?)["&]', + webpage) if multiple_urls: entries = [self.url_result(u, ie='IGN') for u in multiple_urls] return { @@ -125,10 +129,14 @@ class IGNIE(InfoExtractor): formats = [] m3u8_url = api_data['refs'].get('m3uUrl') if m3u8_url: - formats.extend(self._extract_m3u8_formats(m3u8_url, video_id)) + m3u8_formats = self._extract_m3u8_formats(m3u8_url, video_id, 'mp4', 'm3u8_native', m3u8_id='hls', fatal=False) + if m3u8_formats: + formats.extend(m3u8_formats) f4m_url = api_data['refs'].get('f4mUrl') if f4m_url: - formats.extend(self._extract_f4m_formats(f4m_url, video_id)) + f4m_formats = self._extract_f4m_formats(f4m_url, video_id, f4m_id='hds', fatal=False) + if f4m_formats: + formats.extend(f4m_formats) for asset in api_data['assets']: formats.append({ 'url': asset['url'], @@ -139,9 +147,9 @@ class IGNIE(InfoExtractor): }) self._sort_formats(formats) - thumbnails = [] - for thumbnail in api_data['thumbnails']: - thumbnails.append({'url': thumbnail['url']}) + thumbnails = [{ + 'url': thumbnail['url'] + } for thumbnail in api_data.get('thumbnails', [])] metadata = api_data['metadata'] @@ -152,6 +160,7 @@ class IGNIE(InfoExtractor): 'timestamp': parse_iso8601(metadata.get('publishDate')), 'duration': int_or_none(metadata.get('duration')), 'display_id': metadata.get('slug') or video_id, + 'uploader_id': metadata.get('creator'), 'thumbnails': thumbnails, 'formats': formats, } @@ -171,6 +180,7 @@ class OneUPIE(IGNIE): 'description': 'md5:bf0516c5ee32a3217aa703e9b1bc7826', 'timestamp': 1313099220, 'upload_date': '20110811', + 'uploader_id': 'IGN', } }] @@ -197,6 +207,7 @@ class PCMagIE(IGNIE): 'description': 'md5:a7071ae64d2f68cc821c729d4ded6bb3', 'timestamp': 1420571160, 'upload_date': '20150106', + 'uploader_id': '[email protected]', } },{ 'url': 'http://www.pcmag.com/article2/0,2817,2470156,00.asp', @@ -208,5 +219,6 @@ class PCMagIE(IGNIE): 'description': 'md5:53433c45df96d2ea5d0fda18be2ca908', 'timestamp': 1412953920, 'upload_date': '20141010', + 'uploader_id': '[email protected]', } }] |