Подпроцесс застревает в poller.poll()
Я пытаюсь запустить простой интерфейс Matlab на Nipype, как показано ниже, но каким-то образом он застревает в коде run(). Моя командная строка больше не продолжается. Но это прекрасно работает, если я скопирую mlab.cmdline (matlab -nodesktop -nosplash -singleCompThread -r "addpath('/somepath');pyscript;exit") и вставлю его в командную строку.
import nipype.interfaces.matlab as matlab
mlab = matlab.MatlabCommand()
mlab.inputs.script = """ 1+2 """
print mlab.cmdline
res = mlab.run()
print res.runtime
вот прерывание клавиатуры ipython:
^C---------------------------------------------------------------------------
KeyboardInterrupt Traceback (most recent call last)
/usr/lib/python2.7/dist-packages/IPython/utils/py3compat.pyc in execfile(fname, *where)
173 else:
174 filename = fname
--> 175 __builtin__.execfile(filename, *where)
/new_home/intern2012/yasin/example.py in <module>()
6
7 print mlab.cmdline
----> 8 res = mlab.run()
9
10 print res.runtime
/usr/lib/pymodules/python2.7/nipype/interfaces/base.pyc in run(self, **inputs)
944 version=self.version)
945 try:
--> 946 runtime = self._run_interface(runtime)
947 outputs = self.aggregate_outputs(runtime)
948 runtime.endTime = dt.isoformat(dt.utcnow())
/usr/lib/pymodules/python2.7/nipype/interfaces/matlab.pyc in _run_interface(self, runtime)
136 def _run_interface(self,runtime):
137 self.inputs.terminal_output = 'allatonce'
--> 138 runtime = super(MatlabCommand, self)._run_interface(runtime)
139 try:
140 # Matlab can leave the terminal in a barbbled state
/usr/lib/pymodules/python2.7/nipype/interfaces/base.pyc in _run_interface(self, runtime, correct_return_codes)
1378 setattr(runtime, 'dependencies', get_dependencies(executable_name,
1379 runtime.environ))
-> 1380 runtime = run_command(runtime, output=self.inputs.terminal_output)
1381 if runtime.returncode is None or \
1382 runtime.returncode not in correct_return_codes:
/usr/lib/pymodules/python2.7/nipype/interfaces/base.pyc in run_command(runtime, output, timeout)
1150 result['merged'] = [r[1] for r in temp]
1151 if output == 'allatonce':
-> 1152 stdout, stderr = proc.communicate()
1153 result['stdout'] = stdout.split('\n')
1154 result['stderr'] = stderr.split('\n')
/usr/lib/python2.7/subprocess.pyc in communicate(self, input)
752 return (stdout, stderr)
753
--> 754 return self._communicate(input)
755
756
/usr/lib/python2.7/subprocess.pyc in _communicate(self, input)
1310
1311 if _has_poll:
-> 1312 stdout, stderr = self._communicate_with_poll(input)
1313 else:
1314 stdout, stderr = self._communicate_with_select(input)
/usr/lib/python2.7/subprocess.pyc in _communicate_with_poll(self, input)
1364 while fd2file:
1365 try:
-> 1366 ready = poller.poll()
1367 except select.error, e:
1368 if e.args[0] == errno.EINTR:
Я читал другие subprocess
проблемы на этом сайте, но все они связаны с Popen()
, В моем случае что-то не так с poller.poll()
, Он больше не обрабатывает, когда достигает этой строки.
1 ответ
Мне не удалось воспроизвести это поведение (иначе "работает для меня!"). Какую версию nipype вы используете?