Added optional filters property to deepFetch.
authorPawel Solyga <pawel.solyga@gmail.com>
Sat, 01 Aug 2009 14:50:53 +0200
changeset 2702 028f6adffde7
parent 2701 37abba547f8b
child 2703 7117c43ccf1b
Added optional filters property to deepFetch. Note that additional indexes are required whenever this is used. Reviewed by: Lennard de Rijk
scripts/interactive.py
--- a/scripts/interactive.py	Sat Aug 01 13:20:05 2009 +0100
+++ b/scripts/interactive.py	Sat Aug 01 14:50:53 2009 +0200
@@ -27,10 +27,10 @@
 
 __authors__ = [
   '"Sverre Rabbelier" <sverre@rabbelier.nl>',
+  '"Pawel Solyga" <pawel.solyga@gmail.com>',
 ]
 
 
-
 import code
 import getpass
 import os
@@ -44,12 +44,13 @@
   return raw_input('Username:'), getpass.getpass('Password:')
 
 
-def deepFetch(queryGen,key=None,batchSize = 100):
+def deepFetch(queryGen, key=None, filters=None, batchSize = 100):
   """Iterator that yields an entity in batches.
 
   Args:
     queryGen: should return a Query object
     key: used to .filter() for __key__
+    filters: dict with additional filters
     batchSize: how many entities to retrieve in one datastore call
 
   Retrieved from http://tinyurl.com/d887ll (AppEngine cookbook).
@@ -58,7 +59,7 @@
   from google.appengine.ext import db
 
    # AppEngine will not fetch more than 1000 results
-  batchSize = min(batchSize,1000)
+  batchSize = min(batchSize, 1000)
 
   query = None
   done = False
@@ -70,8 +71,14 @@
   while not done:
     print count
     query = queryGen()
+
+    if filters:
+      for key, value in filters.items():
+        query.filter(key, value)
+
     if key:
-      query.filter("__key__ > ",key)
+      query.filter("__key__ > ", key)
+
     results = query.fetch(batchSize)
     for result in results:
       count += 1