25

Flask、MongoDB、および Python を使用して単純な Hello World アプリを動作させるのに問題があります。モジュールからインポートしようとすると、アプリが爆撃しbsonます。すべてのモジュールが 経由pipで正常にインストールされ、 で実行しているvirtualenvため、エラーが発生する理由がわかりません:ImportError: cannot import name BSON

これが私のサンプルアプリコードです:

import os
from flask import Flask
from flask import g
from flask import jsonify
from flask import json
from flask import request
from flask import url_for
from flask import redirect
from flask import render_template
from flask import make_response
import pymongo
from pymongo import Connection
from bson import BSON
from bson import json_util

app = Flask(__name__)

@app.route('/')
def hello():

    connection = Connection()
    # Get your DB
    db = connection.my_database
    # Get your collection
    cars = db.cars
    # Create some objects
    import datetime
    car = {"brand": "Ford",
           "model": "Mustang",
           "date": datetime.datetime.utcnow()}
    # Insert it
    cars.insert(car)
    json_docs = [json.dumps(doc, default=json_util.default) for doc in cars.find()]

    return json_docs


if __name__ == '__main__':
    # Bind to PORT if defined, otherwise default to 5000.
    port = int(os.environ.get('PORT', 5000))
    app.debug = True
    app.run(host='0.0.0.0', port=port)

これをデバッグする方法がわかりません。または、ここに欠けているものがあるかどうかもわかりません。

編集: の結果pip freeze:

Flask==0.9
Jinja2==2.6
WTForms==1.0.2
Werkzeug==0.8.3
bson==0.3.3
distribute==0.6.28
mongo==0.2.0
pymongo==2.3
pytz==2012g
wsgiref==0.1.2

Edit2: bson と pymongo を削除し、再実行しましpip install pymongoた。今すぐトレースを完了してください:

Traceback (most recent call last):
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/flask/app.py", line 1701, in __call__
18:21:20 web.1  |     return self.wsgi_app(environ, start_response)
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/flask/app.py", line 1689, in wsgi_app
18:21:20 web.1  |     response = self.make_response(self.handle_exception(e))
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/flask/app.py", line 1687, in wsgi_app
18:21:20 web.1  |     response = self.full_dispatch_request()
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/flask/app.py", line 1361, in full_dispatch_request
18:21:20 web.1  |     response = self.make_response(rv)
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/flask/app.py", line 1450, in make_response
18:21:20 web.1  |     rv = self.response_class.force_type(rv, request.environ)
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/werkzeug/wrappers.py", line 711, in force_type
18:21:20 web.1  |     response = BaseResponse(*_run_wsgi_app(response, environ))
18:21:20 web.1  |   File ".../venv/lib/python2.7/site-packages/werkzeug/test.py", line 818, in run_wsgi_app
18:21:20 web.1  |     app_iter = app(environ, start_response)
18:21:20 web.1  | TypeError: 'list' object is not callable
4

3 に答える 3

80

bsonおよびパッケージをアンインストールしてから、pymongoパッケージを再インストールしてみてくださいpymongopymongo独自のbsonパッケージをインストールしますが、他のパッケージのインストールで上書きしたと思います。これがbson、インポートエラーの原因である可能性があります。

ご参考までに:

  • pip install pymongoを実行すると、bsonもインストールされますが、virtualenvサイトパッケージにbsonがインストールされていることを示すメッセージは出力されません。
  • また、pymongoはbsonをdepとしてリストしません
  • また、pip -v listは、bsonがインストールされていることを示していません
  • これらの箇条書きIMOにはコードの臭いがあります(少なくとも、bsonをインストールしていることを示すメッセージを印刷してください)
于 2012-10-19T23:13:03.833 に答える
6

でリストを返していますhello()。文字列または Response オブジェクトを返す必要があります。 Flask docsを参照してください。たとえば、返す前にリストを文字列に変換します。

return '\n'.join(json_docs)
于 2012-10-19T23:30:47.070 に答える