I used a slightly modified solution from this thread to get a set of randomly chosen items from Datastore. I use ProtoRPC, though it doesn't make much difference, just for your information. My code looks like this:
@remote.method(RandomImagesRequest, RandomImagesResponse)
def get_random_images(self, request):
images = []
count = request.count
for i in range(0, count):
random_number = random.random()
img = Image.all().order('random_number').filter('random_number>=', random_number).get()
if img is None:
img = Image.all().order('-random_number').filter('random_number <', random_number).get()
image_message = ImageMessage(image_url=img.image_url)
images.append(image_message)
return RandomImagesResponse(images=images)
This way I get any number of randomly chosen items. But sometimes there duplicates appear. How to effectively get only unique items from Datastore?