Add entityIterator to base Logic
authorSverre Rabbelier <srabbelier@gmail.com>
Sun, 19 Apr 2009 00:06:29 +0000 (2009-04-19)
changeset 2230 f3d59025d254
parent 2229 b36ecf371aef
child 2231 6077018a1e68
Add entityIterator to base Logic Patch by: Sverre Rabbelier
app/soc/logic/models/base.py
--- a/app/soc/logic/models/base.py	Sun Apr 19 00:06:12 2009 +0000
+++ b/app/soc/logic/models/base.py	Sun Apr 19 00:06:29 2009 +0000
@@ -508,6 +508,36 @@
 
     return result
 
+  def entityIterator(self, queryGen, batchSize = 100):
+    """Iterator that yields an entity in batches.
+
+    Args:
+      queryGen: should return a Query object
+      batchSize: how many entities to retrieve in one datastore call
+
+    Retrieved from http://tinyurl.com/d887ll (AppEngine cookbook).
+    """
+
+     # AppEngine will not fetch more than 1000 results
+    batchSize = min(batchSize,1000)
+
+    done = False
+    count = 0
+    key = None
+
+    while not done:
+      query = queryGen()
+      if key:
+        query.filter("__key__ > ",key)
+      results = query.fetch(batchSize)
+      for result in results:
+        count += 1
+        yield result
+      if batchSize > len(results):
+        done = True
+      else:
+        key = results[-1].key()
+
   def _createField(self, entity_properties, name):
     """Hook called when a field is created.