3

概要:

私は時々セロリで何かを作らなければならないアプリケーションを持っています-そしてそれが何かを数えるなどの単純なタスクであれば、すべて問題ありません。

MS Windows プログラムを使用して、既存のファイルを別のファイルに変換する必要があるタスクが 1 つあります。それで、私は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:~$ 
4

1 に答える 1

3

使用する

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()

それが何に印刷されるかを見て、あなたが間違っていることを理解するstdoutstderr

編集:Xvfb偽のフレームバッファです。ハードウェアアクセラレーションはありません。wineハードウェア アクセラレーションを必要としないように / OpenGL を使用しないように / でソフトウェア レンダリングを行うように、設定を変更してみてくださいwinecfg

于 2011-07-22T12:31:36.317 に答える