mirror of
				https://code.hackerspace.pl/q3k/youtube-dl
				synced 2025-03-16 11:43:02 +00:00 
			
		
		
		
	Merge branch 'master' of github.com:rg3/youtube-dl
Conflicts: youtube_dl/extractor/__init__.py
This commit is contained in:
		
						commit
						ac1390eee8
					
				| @ -112,11 +112,11 @@ class TestYoutubeLists(unittest.TestCase): | |||||||
|     def test_youtube_mix(self): |     def test_youtube_mix(self): | ||||||
|         dl = FakeYDL() |         dl = FakeYDL() | ||||||
|         ie = YoutubePlaylistIE(dl) |         ie = YoutubePlaylistIE(dl) | ||||||
|         result = ie.extract('http://www.youtube.com/watch?v=lLJf9qJHR3E&list=RDrjFaenf1T-Y') |         result = ie.extract('https://www.youtube.com/watch?v=W01L70IGBgE&index=2&list=RDOQpdSVF_k_w') | ||||||
|         entries = result['entries'] |         entries = result['entries'] | ||||||
|         self.assertTrue(len(entries) >= 20) |         self.assertTrue(len(entries) >= 20) | ||||||
|         original_video = entries[0] |         original_video = entries[0] | ||||||
|         self.assertEqual(original_video['id'], 'rjFaenf1T-Y') |         self.assertEqual(original_video['id'], 'OQpdSVF_k_w') | ||||||
| 
 | 
 | ||||||
|     def test_youtube_toptracks(self): |     def test_youtube_toptracks(self): | ||||||
|         print('Skipping: The playlist page gives error 500') |         print('Skipping: The playlist page gives error 500') | ||||||
|  | |||||||
| @ -267,6 +267,7 @@ from .swrmediathek import SWRMediathekIE | |||||||
| from .syfy import SyfyIE | from .syfy import SyfyIE | ||||||
| from .sztvhu import SztvHuIE | from .sztvhu import SztvHuIE | ||||||
| from .tagesschau import TagesschauIE | from .tagesschau import TagesschauIE | ||||||
|  | from .teachingchannel import TeachingChannelIE | ||||||
| from .teamcoco import TeamcocoIE | from .teamcoco import TeamcocoIE | ||||||
| from .techtalks import TechTalksIE | from .techtalks import TechTalksIE | ||||||
| from .ted import TEDIE | from .ted import TEDIE | ||||||
|  | |||||||
							
								
								
									
										33
									
								
								youtube_dl/extractor/teachingchannel.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								youtube_dl/extractor/teachingchannel.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | |||||||
|  | from __future__ import unicode_literals | ||||||
|  | 
 | ||||||
|  | import re | ||||||
|  | 
 | ||||||
|  | from .common import InfoExtractor | ||||||
|  | from .ooyala import OoyalaIE | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class TeachingChannelIE(InfoExtractor): | ||||||
|  |     _VALID_URL = r'https?://www\.teachingchannel\.org/videos/(?P<title>.+)' | ||||||
|  | 
 | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'https://www.teachingchannel.org/videos/teacher-teaming-evolution', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': 'F3bnlzbToeI6pLEfRyrlfooIILUjz4nM', | ||||||
|  |             'ext': 'mp4', | ||||||
|  |             'title': 'A History of Teaming', | ||||||
|  |             'description': 'md5:2a9033db8da81f2edffa4c99888140b3', | ||||||
|  |         }, | ||||||
|  |         'params': { | ||||||
|  |             # m3u8 download | ||||||
|  |             'skip_download': True, | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         mobj = re.match(self._VALID_URL, url) | ||||||
|  |         title = mobj.group('title') | ||||||
|  |         webpage = self._download_webpage(url, title) | ||||||
|  |         ooyala_code = self._search_regex( | ||||||
|  |             r'data-embed-code=\'(.+?)\'', webpage, 'ooyala code') | ||||||
|  | 
 | ||||||
|  |         return OoyalaIE._build_url_result(ooyala_code) | ||||||
| @ -223,6 +223,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor, SubtitlesInfoExtractor): | |||||||
|         '246': {'ext': 'webm', 'height': 480, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, |         '246': {'ext': 'webm', 'height': 480, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '247': {'ext': 'webm', 'height': 720, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, |         '247': {'ext': 'webm', 'height': 720, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|         '248': {'ext': 'webm', 'height': 1080, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, |         '248': {'ext': 'webm', 'height': 1080, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
|  |         '271': {'ext': 'webm', 'height': 1440, 'format_note': 'DASH video', 'acodec': 'none', 'preference': -40}, | ||||||
| 
 | 
 | ||||||
|         # Dash webm audio |         # Dash webm audio | ||||||
|         '171': {'ext': 'webm', 'vcodec': 'none', 'format_note': 'DASH audio', 'abr': 48, 'preference': -50}, |         '171': {'ext': 'webm', 'vcodec': 'none', 'format_note': 'DASH audio', 'abr': 48, 'preference': -50}, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Philipp Hagemeister
						Philipp Hagemeister