Google App Engine:get_by_id结果长度?

0 投票
2 回答
570 浏览
提问于 2025-04-16 17:20

我该怎么获取 get_by_id 的长度呢?

比如我有这样的代码:

query = Model.get_by_id(1)

我试过

if len(query) == 1if 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

撰写回答