Python 子流程未调用我的命令(或执行错误)

Python 子流程未调用我的命令(或执行错误),python,django,celery,wine,xvfb,Python,Django,Celery,Wine,Xvfb,概述: 我有一个应用程序,有时必须做一些芹菜-如果它是简单的任务,如计数的东西-一切都是好的 我有一个任务,必须使用MS Windows程序将现有文件转换为另一个文件。因此-我安装了WINE,然后安装了应用程序,并将以下任务添加到我的tasks.py中: def convert_file( fil, to_format = 'pdf', save_to = '/tmp', callback = None ): devnull = open( '/dev/null', 'w' )

概述:

我有一个应用程序,有时必须做一些芹菜-如果它是简单的任务,如计数的东西-一切都是好的

我有一个任务,必须使用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或交互式pythonshell调用该命令,一切都正常

编辑: 当我从命令行调用命令时,我得到以下信息:

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:~$ 
使用

为了你的Popen命令

print p.communicate()
p.wait()
print p.communicate()
查看打印到
stdout
stderr
的内容,找出您做错了什么

编辑:
Xvfb
是一个伪帧缓冲区;它没有硬件加速。尝试更改您的
wine
设置,使其不需要硬件加速/不使用OpenGL/使用
winecfg

p进行软件渲染。communicate()方法很好-我在文档中错过了它-我的问题用它解决了
print p.communicate()
p.wait()
print p.communicate()