记录未显示在模板中

时间:2012-11-30 18:29:02

标签: python django django-generic-views

我在Windows 7上运行Python 2.7.2和Django 1.4.1。

我在sqlite db中有几条记录,我试图使用泛型类视图ListView显示它们。我已经消除了它不可能的东西,并将所有内容剥离到最简单的格式,但我不知道该去哪里弄清楚它可能是什么。

型号:

class DMG_New_Inv (models.Model): # DMG's
def __init__(self, *args, **kwargs):
    super(DMG_New_Inv, self).__init__(*args, **kwargs)
    self.objects = None

model_num = models.ForeignKey(DMG_Models_Default, verbose_name='Model')
serial_num = models.CharField(max_length=25, verbose_name='Serial Number')
date_in = models.DateField(auto_now_add=True) #this will set the date to the creation date automaticly
date_out = models.DateField(blank=True, null=True) # the date is was removed from inventory
status = models.CharField(max_length=2, verbose_name='Asset Status', choices=DMG_ASSET_STATUS) # see list above
company = models.CharField(max_length=50, verbose_name='Company', blank=True, null=True) # the company or person who received the product
notes = models.CharField(max_length=255, verbose_name='Notes',  blank=True, null=True)
pass
class Meta:
    verbose_name = 'DMG'
    verbose_name_plural = 'DMGs'

查看:

from django.views.generic import list
from django.views.generic import ListView
from django.shortcuts import get_object_or_404

from inventory.models import DMG_New_Inv

class dmg_new_status(ListView):

context_object_name = "dmg_new_status"
template_name = 'inventory/dmg_inv.html'

def get_queryset(self):
    status = get_object_or_404(DMG_New_Inv, status__iexact=self.args[0])
    return DMG_New_Inv.objects.filter(status__iexact=status)

内容:

{% block content %}

<div id="content">

<table cellspacing="3" cellpadding="3">
    <tr align="center">
        <th>Model</th><th>Serial Number</th><th>Date In</th><th>Date Out</th><th>Status</th><th>Company</th><th>Notes</th>
    </tr>
    {% for dmg in dmg_new_status %}

    <tr align="center">
        <td>{{ dmg.model_num }}</td>
        <td>{{ dmg.serial_num }}</td>
        <td>{{ dmg.date_in }}</td>
        <td>{{ dmg.date_out }}</td>
        <td>{{ dmg.status }}</td>
        <td> {{ dmg.company }}</td>
        <td> {{ dmg.notes }}</td>
    </tr>
    {% empty %}
    No DMG's in this list
    {% endfor %}
</table>

    {%endblock%}

URL:

(r'^inventory/dmg/(\w+)/$', dmg_new_status.as_view()), #status page

我确定这不是路径问题,因为我添加了空选项,它显示表头但没有记录。如果我不得不猜测,我猜测,我没有返回任何东西,因此数组是空的。我不知道如何进一步解决这个问题。我打开一个控制台导入所有内容并以这种方式运行query_set函数并且什么都没有,这就是为什么我认为错误就在那里。

由于

1 个答案:

答案 0 :(得分:1)

看起来你在get_queryset(self)中遇到了问题...... 第一行获取DMG_New_Inv对象,但您将其分配给变量状态。

最后一行不应该像......

return DMG_New_Inv.objects.filter(status__iexact=status.status)

(您也可能想要使用与“状态”不同的变量)