祖先查询不显示结果

时间:2013-03-24 00:48:32

标签: python google-app-engine python-2.7 google-cloud-datastore jinja2

我无法让ancestor queries显示与存储在数据存储区中的Tom's张照片相关联的链接。即使数据存储区中有多个链接,数据存储区也不会显示任何内容。任何帮助将不胜感激。提前谢谢。

main.py

import webapp2
import jinja2
import os

from google.appengine.ext import db

jinja_environment = jinja2.Environment(
    loader=jinja2.FileSystemLoader(os.path.dirname(__file__)))

class MainPage(webapp2.RequestHandler):
    def get(self):          

        tom = Person(key_name='Tom')

        wedding_photo = Photo(parent=tom)
        wedding_photo.image_url='http://pinterest.com/pin/200691727117011230/'
        wedding_photo.put()

        baby_photo = Photo(parent=tom)
        baby_photo.image_url='http://pinterest.com/pin/518828819542052681/'
        baby_photo.put()

        dance_photo = Photo(parent=tom)
        dance_photo.image_url='http://pinterest.com/pin/257197828689352707/'
        dance_photo.put()

        dog_photo = Photo()
        dog_photo.image_url='http://pinterest.com/pin/279575089339614779/'
        dog_photo.put()


        photo_query = Photo.all()
        photo_query.ancestor(tom)

        message = "Photos"

        template_values = {
            'message': message,
            'photo_query': photo_query,     
        }       

        template = jinja_environment.get_template('index.html')
        self.response.out.write(template.render(template_values))


class PhotoStore(webapp2.RequestHandler):
    def post(self):
        photo = Photo()
        photo.image_url = self.request.get('image_url')     
        photo.put() 
        self.redirect('/')      


class Person(db.Model):
    name = db.StringProperty()


class Photo(db.Model):
    image_url = db.StringProperty()

app = webapp2.WSGIApplication([('/', MainPage),
                                ('/new_photo',PhotoStore)], debug=True)

的index.html

<html>
    <body>                      
        <form action="/new_photo" method="post">            
            <label for="photo">Photo</label>
            <div><textarea name="image_url" rows="1" cols="60" id="image_url"></textarea></div>         
            <input type="submit" value="Submit">
        </form>
        <hr></hr>
        <div><b>{{ message }}</b></div>             
        <b>{% for p in photo_query.run(limit=5): %}</b>
        <div>{{ p }}</div>
        <b>{% endfor %}</b>
    </body>
</html>

1 个答案:

答案 0 :(得分:2)

如果打开生成的html源代码,您会看到什么?我假设代码{{ p }}只显示Photo个对象的字符串表示,这导致显示像<__main__.Photo object at 0xfcbd9ef0>这样的字符串,它被解释为HTML标记,并且不会在呈现的HTML中显示。