5

对不起,如果它是一个菜鸟代码或问题。我正在使用 django-pagination 进行分页,我这样做是这样的。但这在我的页面上给了我 keyError 并且它提到它在模板渲染期间出现错误。我在这里做错了什么。我已经成功安装了分页,修改了 settings.py 文件。但我不知道我需要在这里做什么。任何帮助将不胜感激。

 <table class="active_table"  summary="active_user">
    <thead>
     <tr><th>Name</th><th>Mobile Number</th><th>Count</th></tr>
    </thead>
    <tbody id="table_content">
     {% load pagination_tags %}
       {% block content %}
         {% autopaginate response_data 5 %}
           {% for b in response_data %}
              <tr class="table_rows"><td>{{ b.name }}</td><td>{{ b.mobile_number }}</td><td>{{ b.count }}</td></tr>
           {% endfor %}
         {% paginate %}
        {% endblock %}
     </tbody>
  </table>

详细的回溯粘贴在这里http://dpaste.com/919526/

视图代码如下

视图.py

@csrf_exempt

def active_user_table(request, b): if request.method != "GET": raise Http404

if (b=='4'):
         cursor = connection.cursor()
         cursor.execute("SELECT core_user.id, name,mobile_number,COUNT(*) as count, created FROM core_user,core_useractivity WHERE core_user.id = core_useractivity.user_id GROUP BY user_id ORDER BY count DESC")
         response_data = dictfetchall(cursor)
         return render_to_response("siteadmin/active_user_table.tmpl",{'response_data':response_data})
elif (b=='3'):
         cursor = connection.cursor()
         cursor.execute("SELECT core_user.id, name, mobile_number, COUNT(*) as count, created FROM core_user, core_useractivity WHERE core_user.id = core_useractivity.user_id AND MONTH(CAST(created as date)) = MONTH(NOW()) AND YEAR(cast(created as date)) = YEAR(NOW()) GROUP BY user_id ORDER BY count DESC")
         response_data = dictfetchall(cursor)
         return render_to_response("siteadmin/active_user_table.tmpl",{'response_data': response_data})
elif (b=='2'):
         cursor = connection.cursor()
         cursor.execute("SELECT core_user.id, name, mobile_number, COUNT(*) as count, created FROM core_user, core_useractivity WHERE core_user.id = core_useractivity.user_id AND DATEDIFF(NOW(), created) <= 7 GROUP BY user_id ORDER BY count DESC")
         response_data = dictfetchall(cursor)
         return render_to_response("siteadmin/active_user_table.tmpl",{'response_data': response_data})
elif (b=='1'):
         cursor = connection.cursor()
         cursor.execute("SELECT core_user.id, name, mobile_number, COUNT(*) as count, created FROM core_user, core_useractivity WHERE core_user.id = core_useractivity.user_id AND DATE(created) = DATE(NOW())")
         response_data = dictfetchall(cursor)
         return render_to_response("siteadmin/active_user_table.tmpl",{'response_data': response_data})
else:
         raise Http404

抱歉,我现在没有使用 django ORM,但我将来会这样做。

4

4 回答 4

4

我自己解决了这个问题,但感谢 ndpu 的帮助,至少我确信除了一些设置问题之外没有其他问题。在这个问题中,我在设置 django-pagination 时遇到问题。Alasdair 曾提到将“django.contrib.auth.context_processors.auth”添加到 TEMPLATE_CONTEXT_PROCESSORS 中。只需添加它,我就会得到正确的预期值。

于 2013-02-11T11:18:26.253 回答
4

您必须在 render_to_response 调用中添加context_instance :

return render_to_response("siteadmin/active_user_table.tmpl",{'response_data': response_data}, context_instance=RequestContext(request))

或者您可以在 settings.py中使用TEMPLATE_CONTEXT_PROCESSORS元组。将此字符串“django.core.context_processors.request”添加到上下文处理器,每个 RequestContext 都将包含一个变量请求。

于 2013-02-11T10:10:00.037 回答
1

对于那些使用渲染快捷方式 但仍然面临此错误的人,只需添加{'request': request }到上下文变量

context = { ..., 'request':request}
return render(request, 'templatename.html', context)
于 2015-02-21T05:13:05.053 回答
0

我之前也遇到过这个错误。我收到以下错误:内部服务器错误:/cancel-email/

Internal Server Error: /cancel-email/
Traceback (most recent call last):
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/base.py", line 506, in parse
    compile_func = self.tags[command]
KeyError: 'static'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/core/handlers/base.py", line 149, in get_response
    response = self.process_exception_by_middleware(e, request)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/core/handlers/base.py", line 147, in get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/views/decorators/csrf.py", line 58, in wrapped_view
    return view_func(*args, **kwargs)
  File "/var/www/recruiter-new/recruiter/scheduler.py", line 803, in cancelEmail
    return render(request,'scheduler/cancel-email-part.html',{"cancel_email" :EmailDetail})
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/shortcuts.py", line 67, in render
    template_name, context, request=request, using=using)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/loader.py", line 96, in render_to_string
    template = get_template(template_name, using=using)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/loader.py", line 32, in get_template
    return engine.get_template(template_name, dirs)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/backends/django.py", line 40, in get_template
    return Template(self.engine.get_template(template_name, dirs), self)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/engine.py", line 190, in get_template
    template, origin = self.find_template(template_name, dirs)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/engine.py", line 157, in find_template
    name, template_dirs=dirs, skip=skip,
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/loaders/base.py", line 46, in get_template
    contents, origin, origin.template_name, self.engine,
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/base.py", line 189, in __init__
    self.nodelist = self.compile_nodelist()
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/base.py", line 230, in compile_nodelist
    return parser.parse()
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/base.py", line 508, in parse
    self.invalid_block_tag(token, command, parse_until)
  File "/home/kashif/recEnv/lib/python3.6/site-packages/django/template/base.py", line 568, in invalid_block_tag
    "or load this tag?" % (token.lineno, command)
django.template.exceptions.TemplateSyntaxError: Invalid block tag on line 74: 'static'. Did you forget to register or load this tag?
[07/Aug/2018 08:43:26] "POST /cancel-email/ HTTP/1.1" 500 20789

我尝试了一些谷歌解决方案但无法解决,最后再次检查我的代码并在模板文件上发现了一个愚蠢的错误。

只需添加:

{% load static %}

在您的模板文件之上。

于 2018-08-07T09:00:13.540 回答