2012-05-01 18 views
7

ottengo un errore molto strano con MongoKit:MongoKit "ImportError: No module named objectid" errore

>>> from mongokit import * 
Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
    File "/usr/local/lib/python2.7/dist-packages/mongokit/__init__.py", line 35, in <module> 
    from document import Document, ObjectId 
    File "/usr/local/lib/python2.7/dist-packages/mongokit/document.py", line 48, in <module> 
    from pymongo.objectid import ObjectId 
ImportError: No module named objectid 

ho provato di tutto per trovare la ragione, ma niente aiuta. Effettivamente ho cercato su google l'errore "ImportError: No module named objectid" e non ha risultati. Ho provato ad usare MongoKit seguendo il semplice tutorial http://namlook.github.com/mongokit/introduction.html#a-quick-example e la prima riga del tutorial produce questo strano errore. Di seguito è riportato il registro di installazione di MongoKit.

Cosa sto facendo male?

[email protected]:~$ sudo pip install mongokit 
Downloading/unpacking mongokit 
    Downloading mongokit-0.7.2.tar.gz (69Kb): 69Kb downloaded 
    Running setup.py egg_info for package mongokit 

Downloading/unpacking pymongo>=2.0.1 (from mongokit) 
    Downloading pymongo-2.2.tar.gz (228Kb): 228Kb downloaded 
    Running setup.py egg_info for package pymongo 

Downloading/unpacking anyjson>=0.2.2 (from mongokit) 
    Downloading anyjson-0.3.1.tar.gz 
    Running setup.py egg_info for package anyjson 

Installing collected packages: mongokit, pymongo, anyjson 
    Running setup.py install for mongokit 

    Running setup.py install for pymongo 
    building 'bson._cbson' extension 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c bson/_cbsonmodule.c -o build/temp.linux-i686-2.7/bson/_cbsonmodule.o 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c bson/time64.c -o build/temp.linux-i686-2.7/bson/time64.o 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c bson/buffer.c -o build/temp.linux-i686-2.7/bson/buffer.o 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c bson/encoding_helpers.c -o build/temp.linux-i686-2.7/bson/encoding_helpers.o 
    gcc -pthread -shared -Wl,-O1 -Wl,-Bsymbolic-functions -Wl,-Bsymbolic-functions -Wl,-z,relro build/temp.linux-i686-2.7/bson/_cbsonmodule.o build/temp.linux-i686-2.7/bson/time64.o build/temp.linux-i686-2.7/bson/buffer.o build/temp.linux-i686-2.7/bson/encoding_helpers.o -o build/lib.linux-i686-2.7/bson/_cbson.so 
    building 'pymongo._cmessage' extension 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c pymongo/_cmessagemodule.c -o build/temp.linux-i686-2.7/pymongo/_cmessagemodule.o 
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Ibson -I/usr/include/python2.7 -c bson/buffer.c -o build/temp.linux-i686-2.7/bson/buffer.o 
    gcc -pthread -shared -Wl,-O1 -Wl,-Bsymbolic-functions -Wl,-Bsymbolic-functions -Wl,-z,relro build/temp.linux-i686-2.7/pymongo/_cmessagemodule.o build/temp.linux-i686-2.7/bson/buffer.o -o build/lib.linux-i686-2.7/pymongo/_cmessage.so 

    Running setup.py install for anyjson 

Successfully installed mongokit pymongo anyjson 
Cleaning up... 

risposta

11

È un errore nelle dipendenze. A partire da PyMongo 1.11objectid lives in the bson module, not pymongo.

+0

Esiste un modo per risolverlo? O dovrei riscrivere il codice sorgente di terze parti? È una cosa molto semplice, in realtà la prima riga del tutorial e non funziona. 'coz tutto quello che sto facendo - basta importare "da mongokit import *" – Zelid

+0

È un bug segnalato: https://github.com/namlook/mongokit/pull/88 – Electro

+0

grazie, cercherò di installare la versione recente da git – Zelid

10

Come ha detto Electro, è un Bug.

ho usato il seguente piccolo hack sporco per mantenere il mio sito in esecuzione fino a quando non è fisso:

import sys 
import pymongo 
import bson.objectid 
pymongo.objectid = bson.objectid 
sys.modules["pymongo.objectid"] = bson.objectid 
Problemi correlati