python - pymongo中游標的使用
問題描述
問題:我需要多次使用同一個游標。然后發現一個for循環這個游標就沒有用了。然后我使用了
a = db.base.find()c = b = a
但是a for循環之后b,c都不能用了。之后又想到用深度拷貝:
import copya = db.base.find()b = copy.deepcopy(a)c = copy.deepcopy(a)
這樣就可以使用。但是這樣會不會增加內存的使用~!
請問怎么使用才是最優美的呢?謝謝
問題解答
回答1:可以使用itertools的tee
In [20]: from itertools import teeIn [21]: x1,x2 = tee(db.x.find())In [22]: list(x1)Out[22]: [{u’_id’: ObjectId(’590026b521d7dd4a1beb3c1a’), u’name’: u’bar’}, {u’_id’: ObjectId(’590026b921d7dd4a1beb3c1b’), u’name’: u’foo’}]In [23]: list(x2)Out[23]: [{u’_id’: ObjectId(’590026b521d7dd4a1beb3c1a’), u’name’: u’bar’}, {u’_id’: ObjectId(’590026b921d7dd4a1beb3c1b’), u’name’: u’foo’}]
相關文章:
1. objective-c - iPhone如何實現微信的搖一搖功能?2. html5 - h5寫的app用的webview,用手機瀏覽器打開不顯示?3. javascript - 百度echarts series數據更新問題4. javascript - node服務端渲染的困惑5. php - 第三方支付平臺在很短時間內多次異步通知,訂單多次確認收款6. mysql - 一個表和多個表是多對多的關系,該怎么設計7. 請教一個python字符串處理的問題?8. 我在導入模板資源時遇到無法顯示的問題,請老師解答下9. mysql scripts提示 /usr/bin/perl: bad interpreter10. mysql新建字段時 timestamp NOT NULL DEFAULT ’0000-00-00 00:00:00’ 報錯
