我已经安装了 Django 1.9.7,我在 Ubuntu 上安装了 Python 3.4.3 和 2.7.10。
这些是我遵循的步骤:
django-admin startproject testprojectcd testproject/testprojectdjango-admin startapp testappmkdir testapp/templates并在其中添加了一个非常基本的index.html模板编辑settings.py将模板后端更改为django.template.backends.jinja2.Jinja2,通过编辑默认设置文件的第 57 行,并添加testproject.testapp到INSTALLED_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)已编辑urls.py、添加from testproject.testapp import views和 URL 模式url(r'^$', views.index),
编辑testapp/views.py添加
def index(request):
return render(request, 'index.html')
Run Code Online (Sandbox Code Playgroud)cd ..
python3 manage.py runserver, 或python manage.py runserver-- 非常相似的效果运行服务器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。至少,我可以运行python或python3然后import jinja2。pip说 jinja2 是最新的。
我一定遗漏了一些关键的东西——有什么想法吗?
| 归档时间: |
|
| 查看次数: |
1937 次 |
| 最近记录: |