python classmethod get_by_user返回None

时间:2018-02-10 05:10:07

标签: python google-app-engine class-method

我需要帮助才能使用类方法示例get_by_user我接下来会改编类方法。

class Pages(ndb.Model):
    user_id = ndb.StringProperty()
    name = ndb.StringProperty()

    @classmethod
    def get_by_user(cls, user):
        return cls.query().filter(cls.user_id == user.user_id()).get()
接下来是

view.py代码。

class MainPage(BaseHandler):

    def get(self):
    user = users.get_current_user()
    logging.info("MainPageGet: %s " % user)
    if user: #offer user options 
        isUser = True
        user_ID = user
        for p in Pages.query():
        logging.info("MainPageGet p: %s " % p.user_id)
        logging.info("MainPageGet user_ID: %s " % user_ID)
        page = Pages.get_by_user( user_ID) 
        logging.info("MainPageGet page: %s " % page )

我的日志结果如下。

<pre>
INFO     2018-02-10 04:28:21,509 views.py:192] MainPageGet: test@example.com 
INFO     2018-02-10 04:28:21,518 views.py:198] MainPageGet p: test@example.com 
INFO     2018-02-10 04:28:21,519 views.py:198] MainPageGet p: joan@hotmail.com 
INFO     2018-02-10 04:28:21,519 views.py:200] MainPageGet user_ID: test@example.com 
INFO     2018-02-10 04:28:21,524 views.py:204] MainPageGet page: None 
INFO     2018-02-10 04:28:21,535 module.py:812] default: "GET / HTTP/1.1" 200 2284
</pre>

我的示例ndb数据生成如下。

page1 = Pages(id='BS',user_id='test@example.com',name='Brian')
page2 = Pages(id='JS',user_id='joan@hotmail.com',name='Joan')
page1.put()
page2.put()

所以,我的问题是,在最终的记录结果中产生无结果而不是找到test.example.com的{​​{1}}结果,我做错了什么?

1 个答案:

答案 0 :(得分:5)

user.user_id()返回一个ID,至少在开发服务器上是一个数字值,如下所示:185804764220139124118

但是当您创建Pages个实体时,您将其user_id属性的值设置为包含电子邮件地址的字符串:user_id='test@example.com'

因此,get_by_user()内的查询不会返回任何实体,因为没有匹配过滤器。

您可以将get_by_user()修改为类似的内容(在这种情况下,您可能需要调整实际的属性名称,以避免混淆):

    @classmethod
    def get_by_user(cls, user):
        return cls.query().filter(cls.user_id == user.email()).get()