mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-11-04 08:35:12 +00:00 
			
		
		
		
	Authored by: seproDev Reviewed-by: bashonly <88596187+bashonly@users.noreply.github.com> Reviewed-by: Simon Sawicki <contact@grub4k.xyz>
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from .common import InfoExtractor
 | 
						|
from ..utils import (
 | 
						|
    int_or_none,
 | 
						|
    try_get,
 | 
						|
)
 | 
						|
 | 
						|
 | 
						|
class TwentyMinutenIE(InfoExtractor):
 | 
						|
    IE_NAME = '20min'
 | 
						|
    _VALID_URL = r'''(?x)
 | 
						|
                    https?://
 | 
						|
                        (?:www\.)?20min\.ch/
 | 
						|
                        (?:
 | 
						|
                            videotv/*\?.*?\bvid=|
 | 
						|
                            videoplayer/videoplayer\.html\?.*?\bvideoId@
 | 
						|
                        )
 | 
						|
                        (?P<id>\d+)
 | 
						|
                    '''
 | 
						|
    _EMBED_REGEX = [r'<iframe[^>]+src=(["\'])(?P<url>(?:(?:https?:)?//)?(?:www\.)?20min\.ch/videoplayer/videoplayer.html\?.*?\bvideoId@\d+.*?)\1']
 | 
						|
    _TESTS = [{
 | 
						|
        'url': 'http://www.20min.ch/videotv/?vid=469148&cid=2',
 | 
						|
        'md5': 'e7264320db31eed8c38364150c12496e',
 | 
						|
        'info_dict': {
 | 
						|
            'id': '469148',
 | 
						|
            'ext': 'mp4',
 | 
						|
            'title': '85 000 Franken für 15 perfekte Minuten',
 | 
						|
            'thumbnail': r're:https?://.*\.jpg$',
 | 
						|
        },
 | 
						|
    }, {
 | 
						|
        'url': 'http://www.20min.ch/videoplayer/videoplayer.html?params=client@twentyDE|videoId@523629',
 | 
						|
        'info_dict': {
 | 
						|
            'id': '523629',
 | 
						|
            'ext': 'mp4',
 | 
						|
            'title': 'So kommen Sie bei Eis und Schnee sicher an',
 | 
						|
            'description': 'md5:117c212f64b25e3d95747e5276863f7d',
 | 
						|
            'thumbnail': r're:https?://.*\.jpg$',
 | 
						|
        },
 | 
						|
        'params': {
 | 
						|
            'skip_download': True,
 | 
						|
        },
 | 
						|
    }, {
 | 
						|
        'url': 'http://www.20min.ch/videotv/?cid=44&vid=468738',
 | 
						|
        'only_matching': True,
 | 
						|
    }]
 | 
						|
 | 
						|
    def _real_extract(self, url):
 | 
						|
        video_id = self._match_id(url)
 | 
						|
 | 
						|
        video = self._download_json(
 | 
						|
            f'http://api.20min.ch/video/{video_id}/show',
 | 
						|
            video_id)['content']
 | 
						|
 | 
						|
        title = video['title']
 | 
						|
 | 
						|
        formats = [{
 | 
						|
            'format_id': format_id,
 | 
						|
            'url': f'http://podcast.20min-tv.ch/podcast/20min/{video_id}{p}.mp4',
 | 
						|
            'quality': quality,
 | 
						|
        } for quality, (format_id, p) in enumerate([('sd', ''), ('hd', 'h')])]
 | 
						|
 | 
						|
        description = video.get('lead')
 | 
						|
        thumbnail = video.get('thumbnail')
 | 
						|
 | 
						|
        def extract_count(kind):
 | 
						|
            return try_get(
 | 
						|
                video,
 | 
						|
                lambda x: int_or_none(x['communityobject'][f'thumbs_{kind}']))
 | 
						|
 | 
						|
        like_count = extract_count('up')
 | 
						|
        dislike_count = extract_count('down')
 | 
						|
 | 
						|
        return {
 | 
						|
            'id': video_id,
 | 
						|
            'title': title,
 | 
						|
            'description': description,
 | 
						|
            'thumbnail': thumbnail,
 | 
						|
            'like_count': like_count,
 | 
						|
            'dislike_count': dislike_count,
 | 
						|
            'formats': formats,
 | 
						|
        }
 |