2016-12-02 36 views
3

我有一个在Linux中运行良好的Python 3脚本。当我在Windows下运行它,我每一次我尝试播放声音时得到以下回溯:我的异常来源是什么?

Traceback (most recent call last): 
    File "<string>", line 1, in <module> 
    File "C:\Program Files (x86)\Python35-32\lib\multiprocessing\spawn.py", line 106, in spawn_main 
    exitcode = _main(fd) 
    File "C:\Program Files (x86)\Python35-32\lib\multiprocessing\spawn.py", line 116, in _main 
    self = pickle.load(from_parent) 
EOFError: Ran out of input 

我看了,我认为可能是负责这个的代码,但我没有看到如何multiprocessing甚至在这里是相关的,因为我已经抓到了EOFError,或者在我看来。 (请注意,这个例外不会导致我的脚本退出。)

我最大的问题是没有关于Python认为问题发生在哪里的信息。它指的是File "<string>", line 1, in <module>,这是无益的。我怎样才能找出异常实际上升起的位置?

下面是我认为方法必须是负责任的,因为它是我用multiprocessing的唯一的地方:

# imported earlier: 
import multiprocessing as mp 

def _play(self, name): 
    '''Plays the sound given by name''' 
    if self.silent: 
     return True 
    def play_sound(q=None): # Called in a separate process so playing the sound doesn't block anything else. 
     '''q is a multiprocessing.Queue object for interprocess communication.''' 
     try: 
      snd = self.sounds[name] 
      if self._use_subprocess: 
       s = subprocess 
       return s.call([self.player, snd], stdout=s.DEVNULL, stderr=s.DEVNULL, timeout=20) 
      else: 
       return self.player(snd, self._winsound_options) 
     except (KeyboardInterrupt, EOFError): 
      sys.exit(0) 
     except subprocess.TimeoutExpired as e: 
      #if q: 
      # q.put(e) 
      sys.stderr.write('\nSOUND ERROR: Unable to play the sound "{}": Timeout expired.\n\n'.format(snd)) 
      sys.exit(1) 
     except FileNotFoundError: 
      sys.stderr.write('\nSOUND ERROR: Unable to locate the sound player "{}".\n\n'.format(self.player)) 
      sys.exit(2) 
     except EOFError: 
      pass 
    #q = mp.Queue() 
    proc_name = 'Play sound: {}; time: {}'.format(name, datetime.datetime.now().strftime('%I:%M:%S %p')) 
    try: 
     proc = mp.Process(target=play_sound, name=proc_name)#, args=(q,)) 
     proc.start() 
    # On Windows, multiprocessing attempts to pickle this method, which fails 
    # because it's called by an inner function defined in __getattr__. We'll 
    # Skip using multiprocessing in this case. 
    # References: https://github.com/ouspg/trytls/issues/196 and http://stackoverflow.com/a/36995008/713735 
    except (AttributeError, EOFError): 
     play_sound() 
+1

“File”“'部分可以来自运行python代码片段,直接从命令行运行'python -c'这里有一些代码' '。你是否在你的启动脚本中的任何位置执行此操作? –

+0

这的确是它的样子,但我可以向你保证我没有那样做。其他回溯我看起来很正常。 –

+1

您的代码存在一个潜在的问题,那就是在Windows上使用'multiprocessing''',需要将主进程的代码放在'if __name__ =='__main __':'块中。请参阅[_multiprocessing编程准则_](https:/)的[Windows](https://docs.python.org/2/library/multiprocessing.html#windows)部分的主模块**安全导入部分/docs.python.org/2/library/multiprocessing.html#programming-guidelines)。 – martineau

回答

0

我还是不明白,我得到了回溯,但我的工作异常各地通过改变:

proc = mp.Process(target=play_sound, name=proc_name) 
proc.start() 

到:

if os.name == 'nt': 
    play_sound() 
else: 
    proc = mp.Process(target=play_sound, name=proc_name) 
    proc.start() 

是的,我是劳这样的功能,但由于缺乏一个好的终端,该脚本已经在Windows上瘫痪了。 (并且我对Windows没有深刻的理解。)

相关问题