|
|
@ -1,5 +1,6 @@
|
|
|
|
import re
|
|
|
|
import re
|
|
|
|
import urllib.parse
|
|
|
|
import urllib.parse
|
|
|
|
|
|
|
|
import xml.etree.ElementTree
|
|
|
|
|
|
|
|
|
|
|
|
from .common import InfoExtractor
|
|
|
|
from .common import InfoExtractor
|
|
|
|
from ..utils import (
|
|
|
|
from ..utils import (
|
|
|
@ -469,11 +470,12 @@ class SlidesLiveIE(InfoExtractor):
|
|
|
|
slides = self._download_xml(
|
|
|
|
slides = self._download_xml(
|
|
|
|
player_info['slides_xml_url'], video_id, fatal=False,
|
|
|
|
player_info['slides_xml_url'], video_id, fatal=False,
|
|
|
|
note='Downloading slides XML', errnote='Failed to download slides info')
|
|
|
|
note='Downloading slides XML', errnote='Failed to download slides info')
|
|
|
|
slide_url_template = 'https://cdn.slideslive.com/data/presentations/%s/slides/big/%s%s'
|
|
|
|
if isinstance(slides, xml.etree.ElementTree.Element):
|
|
|
|
for slide_id, slide in enumerate(slides.findall('./slide') if slides else [], 1):
|
|
|
|
slide_url_template = 'https://cdn.slideslive.com/data/presentations/%s/slides/big/%s%s'
|
|
|
|
slides_info.append((
|
|
|
|
for slide_id, slide in enumerate(slides.findall('./slide')):
|
|
|
|
slide_id, xpath_text(slide, './slideName', 'name'), '.jpg',
|
|
|
|
slides_info.append((
|
|
|
|
int_or_none(xpath_text(slide, './timeSec', 'time'))))
|
|
|
|
slide_id, xpath_text(slide, './slideName', 'name'), '.jpg',
|
|
|
|
|
|
|
|
int_or_none(xpath_text(slide, './timeSec', 'time'))))
|
|
|
|
|
|
|
|
|
|
|
|
chapters, thumbnails = [], []
|
|
|
|
chapters, thumbnails = [], []
|
|
|
|
if url_or_none(player_info.get('thumbnail')):
|
|
|
|
if url_or_none(player_info.get('thumbnail')):
|
|
|
|