mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 06:35:12 +00:00 
			
		
		
		
	[rtlnl] Extract duration
This commit is contained in:
		| @@ -219,6 +219,7 @@ class TestUtil(unittest.TestCase): | ||||
|         self.assertEqual(parse_duration('0h0m0s'), 0) | ||||
|         self.assertEqual(parse_duration('0m0s'), 0) | ||||
|         self.assertEqual(parse_duration('0s'), 0) | ||||
|         self.assertEqual(parse_duration('01:02:03.05'), 3723.05) | ||||
|  | ||||
|     def test_fix_xml_ampersands(self): | ||||
|         self.assertEqual( | ||||
|   | ||||
| @@ -3,6 +3,7 @@ from __future__ import unicode_literals | ||||
| import re | ||||
|  | ||||
| from .common import InfoExtractor | ||||
| from ..utils import parse_duration | ||||
|  | ||||
|  | ||||
| class RtlXlIE(InfoExtractor): | ||||
| @@ -20,6 +21,7 @@ class RtlXlIE(InfoExtractor): | ||||
|                 'onze mobiele apps.', | ||||
|             'timestamp': 1408051800, | ||||
|             'upload_date': '20140814', | ||||
|             'duration': 576.880, | ||||
|         }, | ||||
|         'params': { | ||||
|             # We download the first bytes of the first fragment, it can't be | ||||
| @@ -35,6 +37,7 @@ class RtlXlIE(InfoExtractor): | ||||
|         info = self._download_json( | ||||
|             'http://www.rtl.nl/system/s4m/vfd/version=2/uuid=%s/fmt=flash/' % uuid, | ||||
|             uuid) | ||||
|  | ||||
|         material = info['material'][0] | ||||
|         episode_info = info['episodes'][0] | ||||
|  | ||||
| @@ -48,4 +51,5 @@ class RtlXlIE(InfoExtractor): | ||||
|             'formats': self._extract_f4m_formats(f4m_url, uuid), | ||||
|             'timestamp': material['original_date'], | ||||
|             'description': episode_info['synopsis'], | ||||
|             'duration': parse_duration(material.get('duration')), | ||||
|         } | ||||
|   | ||||
| @@ -1338,7 +1338,7 @@ def parse_duration(s): | ||||
|         return None | ||||
|  | ||||
|     m = re.match( | ||||
|         r'(?:(?:(?P<hours>[0-9]+)[:h])?(?P<mins>[0-9]+)[:m])?(?P<secs>[0-9]+)s?(?::[0-9]+)?$', s) | ||||
|         r'(?:(?:(?P<hours>[0-9]+)[:h])?(?P<mins>[0-9]+)[:m])?(?P<secs>[0-9]+)s?(?::[0-9]+)?(?P<ms>\.[0-9]+)?$', s) | ||||
|     if not m: | ||||
|         return None | ||||
|     res = int(m.group('secs')) | ||||
| @@ -1346,6 +1346,8 @@ def parse_duration(s): | ||||
|         res += int(m.group('mins')) * 60 | ||||
|         if m.group('hours'): | ||||
|             res += int(m.group('hours')) * 60 * 60 | ||||
|     if m.group('ms'): | ||||
|         res += float(m.group('ms')) | ||||
|     return res | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Philipp Hagemeister
					Philipp Hagemeister