Django在模板中打印sqlite db数据

时间:2015-04-14 14:06:44

标签: python django sqlite templates view

我是django的新手,我在将数据库数据打印到我的页面上时遇到了一些困难。我很感激帮助 - 而且我知道我做的事情很傻但是我有点碰到了。

我已经设置了数据库,我可以访问其中的数据而没有任何问题:

python manage.py shell

>>> from homepage.models import User, Oncall
>>> user_data = User.objects.all()
>>> names = []
>>> for x in user_data:
...  names.append(x.first_name + ' ' + x.last_name)
>>> names
[u'Arthur Mencke', u'John Doe']

那么在我的views.py中我有:

from django.http import HttpResponse
from django.shortcuts import render, get_object_or_404, render_to_response
from django.utils import timezone
import datetime
from homepage.models import User, Oncall
from django.template import RequestContext, loader
from django.template import Template, Context
from django.template.defaulttags import register

def index(request):
        now = timezone.now()
        users = User.objects.all()
        return render(request, 'homepage/index.html')

def getUsers(request):
        users = User.objects.all()
        name_list = []
        for x in users:
                name_list.append(x.first_name + ' ' + x.last_name)
        return name_list

在我的index.html文件中:

{% if name_list %}
        {% for x in name_list %}
                {{ name_list.x }}
        {% endfor %}
{% else %}
        <b>no users</b>
{% endif %}

{{name_list|length}}

这将始终显示在浏览器中:

no users 0

我也试过了name_list [x],并且用相当多的东西捣乱了,没有运气

有什么想法吗?

干杯,亚瑟

1 个答案:

答案 0 :(得分:4)

你做错了,你没有在index视图中传递上下文,举个例子:

def index(request):
    users = User.objects.all()
    return render(request, 'homepage/index.html', {'users': users}) # notice here we are adding our context to be used in template, you need pass it explicitly

然后在index.html

{% for user in users %}
        <span>{{ user.first_name }} {{ user.last_name }}</span>
{% endfor %}