我试图使用PackageLoader jinja2提供,但我无法让它工作。
在我的app.yaml
我声明了所需的库:
libraries:
- name: jinja2
version: latest
- name: setuptools
version: latest
我可以创建的最小例子:
import webapp2, sys
from jinja2 import Environment, PackageLoader
sys.path += ['lib/somepackage']
class Test(webapp2.RequestHandler):
def get(self):
env = Environment(loader=PackageLoader('common'))
self.response.write(env.get_template('test.html').render())
routes = [(r"/", Test)]
app = webapp2.WSGIApplication(routes, debug=True)
包common
存在于目录lib/somepackage
中,并且包templates
包含文件test.html
。 html文件仅包含文本' test'。
构建PackageLoader
后,在Google App Engine中,provider
始终为NullProvider
。当我手动请求提供者时,我得到DefaultProvider
,所以显然这里出了问题。
要请求提供者,请通过转到该目录确保lib/somepackage
位于sys.path
,然后:
>>> import pkg_resources
>>> provider = pkg_resources.get_provider('common')
>>> provider
<pkg_resources.DefaultProvider instance at 0x8490b2c>
如果在Google App Engine中失败,则这是追溯的相关部分:
File "/<>/test/main.py", line 7, in get
self.response.write(env.get_template('test.html').render())
File "/<>/google_appengine/lib/jinja2-2.6/jinja2/environment.py", line 719, in get_template
return self._load_template(name, self.make_globals(globals))
File "/<>/google_appengine/lib/jinja2-2.6/jinja2/environment.py", line 693, in _load_template
template = self.loader.load(self, name, globals)
File "/<>/google_appengine/lib/jinja2-2.6/jinja2/loaders.py", line 115, in load
source, filename, uptodate = self.get_source(environment, name)
File "/<>/google_appengine/lib/jinja2-2.6/jinja2/loaders.py", line 226, in get_source
if not self.provider.has_resource(p):
File "/<>/google_appengine/lib/setuptools-0.6c11/pkg_resources.py", line 1170, in has_resource
return self._has(self._fn(self.module_path, resource_name))
File "/<>/google_appengine/lib/setuptools-0.6c11/pkg_resources.py", line 1218, in _has
"Can't perform this operation for unregistered loader type"
NotImplementedError: Can't perform this operation for unregistered loader type
当我使用FileSystemLoader
而不是它有效时,我觉得这不会在拉链中工作:
import common.templates
env = Environment(loader=FileSystemLoader(common.templates.__path__))
我见过this SO question,但这不是问题所在。
更新
我刚刚测试了1.7.6 SDK中的示例,但这很有效,但是我很乐意看到这个工作在较旧的SDK(或old_dev_appserver)上。
答案 0 :(得分:7)
我认为问题在于pkg_resources
。
部分os
相关功能尚未在GAE中实施,但jinja2或Google提供了一种解决方法。
这些链接说明了这个问题:
http://code.google.com/p/googleappengine/issues/detail?id=60
https://github.com/mitsuhiko/jinja2/issues/143
Jinja2 PackageLoader on google app engine
https://bitbucket.org/tarek/distribute/issue/73/pkg_resources-fails-on-google-app-engine
我已经
了jinja_environment = jinja2.Environment(autoescape=True,
loader=jinja2.FileSystemLoader(os.path.join(os.path.dirname(__file__), 'templates')))
作为样板来获取&#34; template
&#34;目录与设置定义的文件位于同一目录中。但问题是将文件压缩为eggs
并使用PackageLoader
包内是否有__init__.py
文件?你说它在1.7.6上工作了。