【发布时间】:2015-06-16 20:53:33
【问题描述】:
我正在尝试从 python 的 mongodb 集合中插入数据,但没有记录数据。我就是这样做的:
from pymongo import MongoClient
import time
class data2db:
def __init__(self):
pass
def enter_data(self,data):
client = MongoClient('127.0.0.1', 27017)
db = client.db
coll=db.Temperature1
post = {"auth": data ,
"Time" : time.asctime(time.localtime(time.time()))}
post_= coll.insert(post)
c=data2db()
c.enter_data("24.3")
当我尝试从另一个方法访问数据时,它返回 null。我是这样做的:
client = MongoClient('127.0.0.1', 27017)
db = client.db
coll=db.Temperature1
print coll.find_one({"_id" : 1})
print coll.find()
listed=str(coll.find({"_id" : 1})).split(' ')
listed=listed[len(listed)-1].split('>')[0]
listed={"_id" : "ObjectID(\""+listed+"\")"}
print coll.find_one(listed)'''
print db.command("collstats", "events")
如您所见,我已经尝试过不同的方法,但无论如何,它都会返回 null。如果我尝试访问 dbstats,如下所示:
print db.command("dbstats")
我明白了:
{u'extentFreeList': {u'totalSize': 0, u'num': 0}, u'storageSize': 49152, u'ok': 1.0, u'avgObjSize': 64.90566037735849, u'dataFileVersion': {u'major': 4, u'minor': 5}, u'db': u'db', u'indexes': 4, u'objects': 53, u'collections': 6, u'fileSize': 67108864, u'numExtents': 6, u'dataSize': 3440, u'indexSize': 32704, u'nsSizeMB': 16}
该集合甚至没有显示在 mongo 命令行上。急需帮助。
【问题讨论】:
-
我已经复制了你的第一个文件,并执行了它。它为我插入了数据。 (python2.7,mongo3.0.1)。在您的第一个文件中,您能否添加“print post_”并查看结果是什么?它应该返回您插入的文档的 ID。 (如果成功)
-
我已经检查过了。它正在返回文档内容,但集合仍然丢失。我过得很糟糕 :'( 我还检查了我的 mongo 版本是否合规,但这无处可去
-
@WanBachtiar 集合 Temperature1 在您的 mongodb 中可用吗?如果是,请检查 db.Temperture1.find() 是否返回任何内容?您使用的是什么操作系统?
-
是的,该系列可用。我可以使用 python "print list(coll.find())" 进行检查,它会将文档返回给我。我正在使用 Linux Mint。我想尝试回到基本,在 mongo shell 中插入,看看它是否在那里工作。
-
MongoShell 和 mongojava 工作得很好。我特别需要 python,因为我正在使用一个用于 ist python 的用例的 API。无论如何,问题终于解决了,但现在还有另一个问题,但是当我发布 {"Temperature" : 24.3} 并发送查询时,mongo 返回 {"_id": ObjectId("558019749f43b8c19779c106"),"Temperature" : -0.00000789320} 可以你猜是什么问题?像 12 这样的整数工作正常