无法使用 Django 设置 Jinja2

tre*_*mby 1 django jinja2

我已经安装了 Django 1.9.7,我在 Ubuntu 上安装了 Python 3.4.3 和 2.7.10。

这些是我遵循的步骤:

  1. 做了一个新项目 django-admin startproject testproject
  2. cd testproject/testproject
  3. 在项目中制作了一个应用程序 django-admin startapp testapp
  4. 为该应用程序中的模板创建了一个目录,mkdir testapp/templates并在其中添加了一个非常基本的index.html模板
  5. 编辑settings.py将模板后端更改为django.template.backends.jinja2.Jinja2,通过编辑默认设置文件的第 57 行,并添加testproject.testappINSTALLED_APPS; TEMPLATES因此,该部分是这样的:

    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.jinja2.Jinja2',
            'DIRS': [],
            'APP_DIRS': True,
            'OPTIONS': {
                'context_processors': [
                    'django.template.context_processors.debug',
                    'django.template.context_processors.request',
                    'django.contrib.auth.context_processors.auth',
                    'django.contrib.messages.context_processors.messages',
                ],
            },
        },
    ]
    
    Run Code Online (Sandbox Code Playgroud)
  6. 已编辑urls.py、添加from testproject.testapp import views和 URL 模式url(r'^$', views.index),

  7. 编辑testapp/views.py添加

    def index(request):
        return render(request, 'index.html')
    
    Run Code Online (Sandbox Code Playgroud)
  8. cd ..

  9. 使用python3 manage.py runserver, 或python manage.py runserver-- 非常相似的效果运行服务器
  10. 拿浏览器去 http://localhost:3000

我收到一个错误。在命令行我得到这个:

Internal Server Error: /
Traceback (most recent call last):
  File "/usr/local/lib/python3.4/dist-packages/django/template/utils.py", line 86, in __getitem__
    return self._engines[alias]
KeyError: 'jinja2'
Run Code Online (Sandbox Code Playgroud)

其次是“在处理上述异常期间”导致的另一个异常,它与我在浏览器中看到的异常相匹配:

Environment:


Request Method: GET
Request URL: http://localhost:3000/

Django Version: 1.9.7
Python Version: 3.4.3
Installed Applications:
['django.contrib.staticfiles', 'testproject.testapp', 'webpack_loader']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']



Traceback:

File "/usr/local/lib/python3.4/dist-packages/django/template/utils.py" in __getitem__
  86.             return self._engines[alias]

During handling of the above exception ('jinja2'), another exception occurred:

File "/usr/local/lib/python3.4/dist-packages/django/core/handlers/base.py" in get_response
  174.                     response = self.process_exception_by_middleware(e, request)

File "/usr/local/lib/python3.4/dist-packages/django/core/handlers/base.py" in get_response
  172.                     response = response.render()

File "/usr/local/lib/python3.4/dist-packages/django/template/response.py" in render
  160.             self.content = self.rendered_content

File "/usr/local/lib/python3.4/dist-packages/django/template/response.py" in rendered_content
  135.         template = self._resolve_template(self.template_name)

File "/usr/local/lib/python3.4/dist-packages/django/template/response.py" in _resolve_template
  90.         new_template = self.resolve_template(template)

File "/usr/local/lib/python3.4/dist-packages/django/template/response.py" in resolve_template
  80.             return select_template(template, using=self.using)

File "/usr/local/lib/python3.4/dist-packages/django/template/loader.py" in select_template
  55.     engines = _engine_list(using)

File "/usr/local/lib/python3.4/dist-packages/django/template/loader.py" in _engine_list
  143.     return engines.all() if using is None else [engines[using]]

File "/usr/local/lib/python3.4/dist-packages/django/template/utils.py" in all
  110.         return [self[alias] for alias in self]

File "/usr/local/lib/python3.4/dist-packages/django/template/utils.py" in <listcomp>
  110.         return [self[alias] for alias in self]

File "/usr/local/lib/python3.4/dist-packages/django/template/utils.py" in __getitem__
  101.             engine = engine_cls(params)

File "/usr/local/lib/python3.4/dist-packages/django/template/backends/jinja2.py" in __init__
  35.         self.env = environment_cls(**options)

Exception Type: TypeError at /
Exception Value: __init__() got an unexpected keyword argument 'context_processors'
Run Code Online (Sandbox Code Playgroud)

我用 Python 2 得到了非常相似的痕迹。

我发现这个问题有一个类似的错误消息(KeyError: 'jinja2'),但似乎是一个单独的问题,这个错误报告再次出现相同的错误,其解决方案是安装 jinja2,但肯定安装了 jinja2。至少,我可以运行pythonpython3然后import jinja2pip说 jinja2 是最新的。

我一定遗漏了一些关键的东西——有什么想法吗?

Ala*_*air 5

错误context_processors是因为 Jinja2 后端不支持该参数。

您应该在您的TEMPLATES设置中添加一个额外的后端,而不是将现有后端从 django 替换为jinja2. 有关更多信息,请参阅此答案。如果您替换现有后端,则需要 Django 模板的应用程序将无法运行,包括管理员。

最后,后端的Jinja2会寻找模板testapp/jinja2,没有testapp/templates