1

我正在将 WTforms 与 GAE 一起使用,并试图找出设置 key_name 值的最佳方法。这有效,但不是很干净。具体来说, p = Posts(key_name... 行似乎是多余的。

class CreatePost(BaseHandler):
def post(self):
    form = MyForm(self.request.POST)
    if form.validate():
        p = Posts()
        p.author = users.get_current_user()
        p.title = form.title.data
        p.path = format_post_path(p)
        p.content = form.content.data
        p = Posts(key_name=p.path, author=p.author, 
                       title=p.title, content=p.content, path=p.path)
        p.put()
        return webapp2.redirect('/admin/')
    else: 
        self.render_template('create.html', {'form':form})

我试过这样做,但它不起作用。

class CreatePost(BaseHandler):
def post(self):
    form = MyForm(self.request.POST)
    if form.validate():
        p = Posts()
        p.author = users.get_current_user()
        p.title = form.title.data
        p.path = format_post_path(p)
        p.content = form.content.data
        p.key_name = p.path
        p.put()
        return webapp2.redirect('/admin/')
    else: 
        self.render_template('create.html', {'form':form})

我的问题:写这个的最好方法是什么?为什么 p.key_name = p.path 不起作用?

更新 1

以下是相关代码:

from models import Posts
import fix_path
import wtforms
from wtforms.ext.appengine.db import model_form
from wtforms import Form, TextField, validators

MyForm = model_form(Posts, Form, field_args = {
    'title' : {
        'validators' : [validators.Length(min=1, max=25)]
    },
    'content' : {
        'validators' : [validators.Length(min=4, max=100000)]
    }
})

def slugify(s):
    s = unicodedata.normalize('NFKD', s).encode('ascii', 'ignore').lower()
    return re.sub('[^a-zA-Z0-9-]+', '-', s).strip('-')


def format_post_path(p):
    slug = slugify(p.title)
    return config.post_path_format % {
        'slug': slug,
        'year': p.date_create.year,
        'month': p.date_create.month,
        'day': p.date_create.day,
   }

class BaseHandler(webapp2.RequestHandler):

    @webapp2.cached_property
    def jinja2(self):
        return jinja2.get_jinja2(app=self.app)

    def render_template(
        self,
        filename,
        template_values,
        **template_args
        ):
        template = fix_path.jinja_environment.get_template(filename)
        self.response.out.write(template.render(template_values))  

class CreatePost(BaseHandler):
    def post(self):
        form = MyForm(self.request.POST)
        if form.validate():
            p = Posts()
            p.author = users.get_current_user()
            p.title = form.title.data
            p.path = format_post_path(p)
            p.key_name = p.path #this part doesn't work. 
                                #No error. Just not value
                                #passed to datastore.
            p.content = form.content.data
            p.put()
            return webapp2.redirect('/admin/')
        else: 
            self.render_template('create.html', {'form':form})

    def get(self):  

        MyForm = model_form(Posts, Form)
        self.render_template('create.html', {'form':MyForm()})

从配置文件

post_path_format = '/%(year)d/%(month)02d/%(slug)s'

我只是不明白为什么我可以使用 p.key_name = p.path 格式(如第一个片段)。为什么我必须这样做 p = Posts(key_name=path, author=p.author..... (就像第二个片段)

谢谢你的帮助。

4

1 回答 1

0

看起来您正在创建一个临时的 Posts 实体,然后使用它的“路径”创建另一个 Posts 实体,您实际保存了它。这在很多方面都搞砸了。

class CreatePost(BaseHandler):
    def post(self):
        form = MyForm(self.request.POST)
        if form.validate():
            p = Posts(key_name=???, users.get_current_user(), title=p.title, content=form.content.data, path=???)
            p.put()
            return webapp2.redirect('/admin/')
        else: 
            self.render_template('create.html', {'form':form})

这就留下了一个问题,什么是“路径”?您需要在不使用现有实体的情况下生成“路径”。

此外,如果“路径”是实体祖先路径,我认为这不是您真正想要的键名。

于 2012-05-16T17:29:32.747 回答