Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/361.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在python中限制mongo查询_Python_Mongodb_Pymongo - Fatal编程技术网

如何在python中限制mongo查询

如何在python中限制mongo查询,python,mongodb,pymongo,Python,Mongodb,Pymongo,我正在尝试使用python从mongodb检索数据。我的数据库包含很多数据。所以我想在检索时限制数据。我试过了 import datetime from pymongo import Connection connection = Connection('localhost',27017) db = connection['MyWork'] db_data = db.myusers.find().limit(2) #db_data = db.myusers.find()[0:2] print

我正在尝试使用python从mongodb检索数据。我的数据库包含很多数据。所以我想在检索时限制数据。我试过了

import datetime
from pymongo import Connection
connection = Connection('localhost',27017)
db = connection['MyWork']


db_data = db.myusers.find().limit(2)
#db_data = db.myusers.find()[0:2]
print db_data
print db_data.count()
print db_data[0]
print db_data[1]
print db_data[2]
但当我尝试上面的方法时,我得到了两个以上的文档。我正在使用
pymongo
驱动程序。如何限制这些值

<pymongo.cursor.Cursor object at 0x000000000267D518>
3
{u'age': 24.0, u'_id': ObjectId('552b6e90aad3e2d909d5fb28'), u'place': u'Ravipadu', u'name': u'Shiva'}
{u'age': 28.0, u'_id': ObjectId('552b6eabaad3e2d909d5fb29'), u'place': u'Rajahmundry', u'name': u'Anil'}
{u'age': 30.0, u'_id': ObjectId('552b6ec1aad3e2d909d5fb2a'), u'place': u'Manchili', u'name': u'Kishore'}

3.
{u'age':24.0,u'id':ObjectId('552b6e90aad3e2d909d5fb28'),u'place':u'Ravipadu',u'name':u'Shiva'}
{u'age':28.0,u'id':ObjectId('552b6eabaad3e2d909d5fb29'),u'place':u'Rajahmundry',u'name':u'Anil'}
{u'age':30.0,u'id':ObjectId('552b6ec1aad3e2d909d5fb2a'),u'place':u'Manchili',u'name':u'Kishore'}
如中所述,索引访问将忽略
限制。和
count()
默认情况下不遵守限制或跳过,如所述。您可以使用限制传递
,并且跳过=True
使
计数()
使用限制

print db_data.count(with_limit_and_skip=True)
或者您可以迭代光标以查看有效的限制

for data in db.myusers.find().limit(2):
    print data
db.myusers.find(limit=2)


如果要应用某些条件,可以使用
db.myusers.find({query},limit=2)
并使用
db.myusers.find({query},limit=2.count()

计算结果数,您尝试过吗?这将返回此游标,限制为2,并跳过应用的0。重复@ForceBru,您尝试过,但仍然获得所有values@philshem,亲爱的,我已经通过了那个链接。但是我没有得到解决方案。请发布更多代码<代码>限制
应该以这种方式工作。其他地方可能有问题。