Jinja2的问题:TemplateNotFound:index.html

时间:2012-06-14 00:40:47

标签: python google-app-engine templates jinja2

我正在尝试用jinja2构建我的第一个GAE应用程序。在克服了十几个小错误后,现在我坚持这个:

Traceback (most recent call last):

File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 1536, in __call__
    rv = self.handle_exception(request, response, e)
  File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 1530, in __call__
    rv = self.router.dispatch(request, response)
  File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 1278, in default_dispatcher
    return route.handler_adapter(request, response)
  File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 1102, in __call__
    return handler.dispatch()
  File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 572, in dispatch
    return self.handle_exception(e, self.app.debug)
  File "C:\Program Files (x86)\Google\google_appengine\lib\webapp2\webapp2.py", line 570, in dispatch
    return method(*args, **kwargs)
  File "C:\Users\CG\Documents\udacity\HiMon\main.py", line 31, in get
    template = jinja_environment.get_template('index.html')
  File "C:\Program Files (x86)\Google\google_appengine\lib\jinja2\jinja2\environment.py", line 719, in get_template
    return self._load_template(name, self.make_globals(globals))
  File "C:\Program Files (x86)\Google\google_appengine\lib\jinja2\jinja2\environment.py", line 693, in _load_template
    template = self.loader.load(self, name, globals)
  File "C:\Program Files (x86)\Google\google_appengine\lib\jinja2\jinja2\loaders.py", line 115, in load
    source, filename, uptodate = self.get_source(environment, name)
  File "C:\Program Files (x86)\Google\google_appengine\lib\jinja2\jinja2\loaders.py", line 180, in get_source
    raise TemplateNotFound(template)
TemplateNotFound: index.html

这是我的yaml文件:

application: himother
version: 1
runtime: python27
api_version: 1
threadsafe: yes

handlers:
- url: /favicon\.ico
  static_files: favicon.ico
  upload: favicon\.ico

- url: .*
  script: main.app

libraries:
- name: webapp2
  version: "2.5.1"
- name: jinja2
  version: "2.6"

这是我的代码:

import os
import webapp2

import jinja2

jinja_environment = jinja2.Environment(autoescape=True,
    loader=jinja2.FileSystemLoader(os.path.join(os.path.dirname(__file__), 'templates')))

class MainPage(webapp2.RequestHandler):
    def get(self):
        template_values = {
            'name': 'Serendipo',
            'verb': 'extremely happy'
        }

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

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

这是我的.html模板:

<!DOCTYPE html>
<html>
    <head>
        <title>Look Ma, I'm using Jinja!</title>
    </head>
    <body>
        Hi there - I'm {{ name }}, and I {{ verb }} programming!
    </body>
</html>

尽管有错误消息,但我有一个名为“templates”的文件夹,并在其中创建了index.html文件:

enter image description here

enter image description here

enter image description here

我也安装了jinja2。

现在有没有人知道这个错误的原因?

6 个答案:

答案 0 :(得分:14)

尝试使用

loader=jinja2.FileSystemLoader('templates')

而不是

loader=jinja2.FileSystemLoader(os.path.join(os.path.dirname(__file__), 'templates'))

它对我有用。

答案 1 :(得分:7)

这解决了我:

mkdir templates
echo "hello world" > templates/index.html

答案 2 :(得分:3)

template_dir = os.path.join(os.path.dirname(__file__), 'templates')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir),autoescape = True)

答案 3 :(得分:2)

基于让我的第一次GAE努力与Jinja2一起工作的两个想法。首先,在你的yaml文件中,你有“-url:。”,虽然我根据我看到的教程使用了“-url:/.”。但是,这可能与您的问题无关。其次,我使用了本页面上的指南来了解我如何建立我的Jinja2渲染器,并且在应用程序目录的templates子目录中找到的模板没有问题:   http://webapp-improved.appspot.com/api/webapp2_extras/jinja2.html#module-webapp2_extras.jinja2

答案 4 :(得分:1)

嗯,我的错误简单而愚蠢。 我以错误的方式创建文件“index.html”(here正确的方式)。所以,我的“index.html”文件确实是一个“.text”文件(因为我只是将其重命名为“index.html”而不是"save as" index.html")。 谢谢你的帮助,伙计们!

答案 5 :(得分:0)

我收到相同的错误,并尝试了所有答案。后来,我知道您首先需要使用正确的文件夹配置环境以搜索html文件,然后jinja2才能找到该文件。

以下几行将消除错误:

env = Environment(loader=FileSystemLoader(searchpath='C:\Folder\of\html\file')
template = env.get_template('Name_of_file.html')