Py2/3 parse_qs compatibility
[youtube-dl] / youtube_dl / InfoExtractors.py
index 8726e943896b0c4b2fdde130eaceb2d22050ed8e..32cdee2cecf8a9ee058657a8d85a1ee9b3122715 100644 (file)
@@ -11,7 +11,6 @@ import email.utils
 import xml.etree.ElementTree
 import random
 import math
-from urlparse import parse_qs
 
 from utils import *
 
@@ -329,7 +328,7 @@ class YoutubeIE(InfoExtractor):
                        request = compat_urllib_request.Request(video_info_url)
                        try:
                                video_info_webpage = compat_urllib_request.urlopen(request).read()
-                               video_info = parse_qs(video_info_webpage)
+                               video_info = compat_parse_qs(video_info_webpage)
                                if 'token' in video_info:
                                        break
                        except (compat_urllib_error.URLError, compat_http_client.HTTPException, socket.error) as err:
@@ -437,7 +436,7 @@ class YoutubeIE(InfoExtractor):
                        video_url_list = [(None, video_info['conn'][0])]
                elif 'url_encoded_fmt_stream_map' in video_info and len(video_info['url_encoded_fmt_stream_map']) >= 1:
                        url_data_strs = video_info['url_encoded_fmt_stream_map'][0].split(',')
-                       url_data = [parse_qs(uds) for uds in url_data_strs]
+                       url_data = [compat_parse_qs(uds) for uds in url_data_strs]
                        url_data = filter(lambda ud: 'itag' in ud and 'url' in ud, url_data)
                        url_map = dict((ud['itag'][0], ud['url'][0] + '&signature=' + ud['sig'][0]) for ud in url_data)
 
@@ -594,7 +593,7 @@ class MetacafeIE(InfoExtractor):
                        if mobj is None:
                                self._downloader.trouble(u'ERROR: unable to extract media URL')
                                return
-                       vardict = parse_qs(mobj.group(1))
+                       vardict = compat_parse_qs(mobj.group(1))
                        if 'mediaData' not in vardict:
                                self._downloader.trouble(u'ERROR: unable to extract media URL')
                                return
@@ -2851,8 +2850,8 @@ class SoundcloudIE(InfoExtractor):
                if mobj:
                        try:
                                upload_date = datetime.datetime.strptime(mobj.group(1), '%B %d, %Y %H:%M').strftime('%Y%m%d')
-                       except Exception, e:
-                               self._downloader.to_stderr(compat_str(e))
+                       except Exception as err:
+                               self._downloader.to_stderr(compat_str(err))
 
                # for soundcloud, a request to a cross domain is required for cookies
                request = compat_urllib_request.Request('http://media.soundcloud.com/crossdomain.xml', std_headers)