UWSGIレシピ:LibreOfficeを使用したドキュメントの変換

ドキュメントの変換を準備するには、LibreOfficeuwsgi-pythonpylokit、およびwebobが必要です。既製の画像を使用することもできますただし、これはuWSGIサーバーを起動するためだけのものであり、nginxを使用してuWSGIサーバーに接続します



最も単純なuWSGIpythonアプリケーションは、environとstart_responseの2つの引数を持つアプリケーション関数で構成されています。



import os       # 
import pylokit  # 
import tempfile # 
import webob    # 

office = pylokit.Office('/usr/lib/libreoffice/program') #   LibreOffice   

def application(environ, start_response): #   uWSGI
    request = webob.Request(environ) #    
    file = request.POST['file'] #      multipart/form-data   file
    filename, extension = os.path.splitext(file.filename) #    
    with tempfile.NamedTemporaryFile(suffix=extension) as inp, tempfile.NamedTemporaryFile(suffix='.%s' % request.path.split('/')[-1]) as out: #                  (   unoconv-api)
        inp.write(file.file.read()) #        
        inp.flush() # (.. LibreOfficeKit -    )
        with office.documentLoad(inp.name) as doc: #    
            doc.saveAs(out.name) #        (   )
            with open(out.name, 'rb') as out2: #    
                response = webob.Response(body=out2.read()) #       
                return response(environ, start_response) #   


もちろん、エラーの処理を追加することもできます。



テストの1ページのodtファイルをpdfに変換することは、unoconv-apiよりも約1.5倍高速です



All Articles