Procházet zdrojové kódy

Fix --extract-audio on Python 3

Philipp Hagemeister před 12 roky
rodič
revize
5910e210f4
2 změnil soubory, kde provedl 8 přidání a 2 odebrání
  1. 2 2
      youtube_dl/PostProcessor.py
  2. 6 0
      youtube_dl/utils.py

+ 2 - 2
youtube_dl/PostProcessor.py

@@ -86,14 +86,14 @@ class FFmpegExtractAudioPP(PostProcessor):
         if not self._exes['ffprobe'] and not self._exes['avprobe']: return None
         if not self._exes['ffprobe'] and not self._exes['avprobe']: return None
         try:
         try:
             cmd = [self._exes['avprobe'] or self._exes['ffprobe'], '-show_streams', '--', encodeFilename(path)]
             cmd = [self._exes['avprobe'] or self._exes['ffprobe'], '-show_streams', '--', encodeFilename(path)]
-            handle = subprocess.Popen(cmd, stderr=file(os.path.devnull, 'w'), stdout=subprocess.PIPE)
+            handle = subprocess.Popen(cmd, stderr=compat_subprocess_get_DEVNULL(), stdout=subprocess.PIPE)
             output = handle.communicate()[0]
             output = handle.communicate()[0]
             if handle.wait() != 0:
             if handle.wait() != 0:
                 return None
                 return None
         except (IOError, OSError):
         except (IOError, OSError):
             return None
             return None
         audio_codec = None
         audio_codec = None
-        for line in output.split('\n'):
+        for line in output.decode('ascii', 'ignore').split('\n'):
             if line.startswith('codec_name='):
             if line.startswith('codec_name='):
                 audio_codec = line.split('=')[1].strip()
                 audio_codec = line.split('=')[1].strip()
             elif line.strip() == 'codec_type=audio' and audio_codec is not None:
             elif line.strip() == 'codec_type=audio' and audio_codec is not None:

+ 6 - 0
youtube_dl/utils.py

@@ -51,6 +51,12 @@ try:
 except ImportError: # Python 2
 except ImportError: # Python 2
     import httplib as compat_http_client
     import httplib as compat_http_client
 
 
+try:
+    from subprocess import DEVNULL
+    compat_subprocess_get_DEVNULL = lambda: DEVNULL
+except ImportError:
+    compat_subprocess_get_DEVNULL = lambda: open(os.path.devnull, 'w')
+
 try:
 try:
     from urllib.parse import parse_qs as compat_parse_qs
     from urllib.parse import parse_qs as compat_parse_qs
 except ImportError: # Python 2
 except ImportError: # Python 2