Google App Engine:get_by_id结果长度?
我该怎么获取 get_by_id 的长度呢?
比如我有这样的代码:
query = Model.get_by_id(1)
我试过
if len(query) == 1
和 if query.count() == 1
这两种方法都不行。
2 个回答
1
来自 http://code.google.com/appengine/docs/python/datastore/modelclass.html#Model_get_by_id:
如果你传入的 ids 是一个字符串,表示一个名字,那么这个方法会返回这个名字对应的模型实例。如果这个实体不存在,它会返回 None。如果 ids 是一个列表,那么这个方法会返回一个模型实例的列表,对于那些没有对应实体的键,会返回 None。
所以可以使用类似这样的代码:
query = Model.get_by_id(1)
if query is None:
print 'Not found'
else:
print 'Returned one result'
如果你有多个 ids 的话:
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
警告:未经测试
4
*Model.get_by_id()* 方法如果只传一个 id,就只会返回一个对象;如果传的是一个 id 列表,它才会返回一个对象列表。这意味着它自然不会有 len 和 count 这些功能。
如果你想检查查询结果是否不为空,可以简单地使用:
query=Model.get_by_id(1)
if query is not None:
如果你想根据键获取对象列表,可以使用 get 方法:
query = MOdel.get(keys) #here keys is a list of keys
if len(query) == 1 will work now