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. javascript - JS設置Video視頻對象的currentTime時出現了問題,IE,Edge,火狐,都可以設置,反而chrom卻...2. javascript - 數組原聲方法中的一段代碼3. 求大神幫我看看是哪里寫錯了 感謝細心解答4. php自學從哪里開始?5. javascript - 如果所有請求都放到actions 里面,那拿到的數據應該 放在哪里,state 還是vue實例里面的data?6. javascript - 怎么實現移動端頁面滑動切換,從1可以滑到2 但是不能從2滑回1 這樣的效果呢?7. 數據庫 - MySQL 單表500W+數據,查詢超時,如何優化呢?8. mysql多表查詢9. phpstady在win10上運行10. python - from ..xxxx import xxxx到底是什么意思呢?
