Как вернуть длину get_by_id ??Google App Engine: длина результата get_by_id?
Например, у меня есть
query = Model.get_by_id(1)
Я попытался
if len(query) == 1
и if query.count() == 1
оба не работают
Как вернуть длину get_by_id ??Google App Engine: длина результата get_by_id?
Например, у меня есть
query = Model.get_by_id(1)
Я попытался
if len(query) == 1
и if query.count() == 1
оба не работают
* Model.get_by_id() * только возвращает единичный объект, если один идентификатор передан, он возвращает al ist объектов, только когда список идентификаторов передан, что означает, что obvioulsy не будет len и считать.
если вы хотите проверить, если запрос не является None, вы можете просто дать
query=Model.get_by_id(1)
if query is not None:
если вы хотите получить список объектов на основе ключей, используйте получить:
query = MOdel.get(keys) #here keys is a list of keys
if len(query) == 1 will work now
От http://code.google.com/appengine/docs/python/datastore/modelclass.html#Model_get_by_id:
Если иды является строка, представляющая одно имя, то метод возвращает экземпляр модели для или Нет, если сущность не существует. Если ids - это список, метод возвращает список экземпляров модели с значением None, если для соответствующего ключа не существует сущности.
Так использовать что-то вроде:
query = Model.get_by_id(1)
if query is None:
print 'Not found'
else:
print 'Returned one result'
для нескольких идентификаторов:
query = Model.get_by_id([1, 2, 3])
count = 0
for item in query:
if item is not None:
print 'Found item ' + str(item)
count += 1
print count
Предупреждение: непроверенную
'Len (query) == 1' будет True тогда и только тогда, когда 'len (keys) == 1' и, в частности, даже если единственный ключ в списке' keys' не соответствует фактическому объекту хранилища данных. – geoffspear