Подпроцесс не вызывает мою команду (или делает это неправильно) - PullRequest
3 голосов
/ 22 июля 2011

Обзор:

У меня есть приложение, которое иногда должно что-то делать с сельдереем - и если это простая задача, такая как подсчет чего-то - все в порядке.

У меня есть одна задача, которая должна преобразовать существующий файл в другой файл с помощью программы MS Windows.Итак, я установил WINE, затем установил приложение и добавил следующую задачу в мои tasks.py:

def convert_file( fil, to_format = 'pdf', save_to = '/tmp', callback = None ):
    devnull = open( '/dev/null', 'w' )
    commands = "xvfb-run -a wine '[ABSOLUTE_PATH_TO_WINDOWS_APP]' /r /f 104 %s" % fil
    p = subprocess.Popen( commands, shell=True, cwd='/home/test', env=os.environ, stdout = devnull, stderr = subprocess.STDOUT )
    p.wait()
    devnull.close()
    if callback:
        subtask( callback ).delay( )
    else:
        return outfile

Проблема:

Команда не вызвана или являетсявызывается, но ничего не происходит (нового файла в файловой системе нет) - но если я вызову эту команду из bash или из интерактивной оболочки python, все в порядке.

Редактировать: Когда я вызываю команду из командной строки, я получаю это:

test@ubuntu:~$ xvfb-run -a /home/test/.wine/....exe /r /f 104 /home/test/fs/...
err:winediag:X11DRV_WineGL_InitOpenglInfo The Mesa OpenGL driver is using software rendering, most likely your OpenGL drivers haven't been installed correctly
test@ubuntu:~$ XIO:  fatal IO error 11 (Zasoby chwilowo niedostępne) on X server ":99"
      after 1262 requests (1226 known processed) with 0 events remaining.
[Here i must press enter]
test@ubuntu:~$ 

1 Ответ

3 голосов
/ 22 июля 2011

Использование

p = subprocess.Popen( commands, shell=True, cwd='/home/test', env=os.environ, stdout = subprocess.PIPE, stderr = subprocess.PIPE)

для вашей команды Popen, затем

print p.communicate()
p.wait()
print p.communicate()

Чтобы увидеть, что он печатает на stdout и stderr и выяснить, что вы делаете неправильно.

Редактировать: Xvfb - фальшивый кадровый буфер; у него нет аппаратного ускорения. Попробуйте изменить настройки wine, чтобы не требовать аппаратного ускорения / не использовать OpenGL / для выполнения программного рендеринга с winecfg.

...