Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/355.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Django:循环一个表中的所有记录,然后从另一个表中获取字段_Python_Django - Fatal编程技术网

Python Django:循环一个表中的所有记录,然后从另一个表中获取字段

Python Django:循环一个表中的所有记录,然后从另一个表中获取字段,python,django,Python,Django,我买了两个叫做买卖的模型: class-Buy(models.Model): 类别=模型.ForeignKey(类别,on_delete=模型.CASCADE) image=models.FileField() date=models.DateField() 购买价格=models.DecimalField(最大位数=6,小数位数=2) 售价=型号。小数点域(最大位数=6,小数点位=2) 定义(自我): 返回str(self.id) 类别销售(models.Model): 项目=模型.OneTo

我买了两个叫做买卖的模型:

class-Buy(models.Model):
类别=模型.ForeignKey(类别,on_delete=模型.CASCADE)
image=models.FileField()
date=models.DateField()
购买价格=models.DecimalField(最大位数=6,小数位数=2)
售价=型号。小数点域(最大位数=6,小数点位=2)
定义(自我):
返回str(self.id)
类别销售(models.Model):
项目=模型.OneToOneField(购买,删除=模型.CASCADE)
date=models.DateField()
折扣=型号。小数字段(最大位数=6,小数位数=2)
支付总额=型号。小数字段(最大位数=6,小数位数=2)
买方=型号.ForeignKey(买方,on_delete=型号.CASCADE)
定义(自我):
返回str(self.item)
在模板中,我想显示Sell表中的所有记录,以及Buy表中的image class属性

下面是my view.py:

def销售(请求):
购买=[]
sells=Sell.objects.order_by('-id'))
对于售后服务:
buys.append(Buy.objects.filter(id=str(sell.item)))
上下文={'sells':sells,'buys':buys}
返回呈现(请求'sell.html',上下文)
模板:

        {% for sell in sells %}
        <tr>
            <td>{{ sell.item }}</td>
            <td>{{ sell.date|date:'d-m-Y' }}</td>
            <td>{{ buys[0].image}}</td>
            <td>R$ {{ sell.discount }}</td>
            <td>R$ {{ sell.total_paid }}</td>
            <td>{{ sell.buyer }}</td>
        </tr>
        {% endfor %}
{%用于销售中的销售%}
{{sell.item}
{{sell.date}日期:'d-m-Y'}
{{[0].image}
R${{sell.discount}
R${sell.total_paid}
{{sell.buyer}}
{%endfor%}

我想知道是否有一个简单的方法可以做到这一点。在我看来,我需要一些帮助。py

您可以访问模板中与
Sell
相关的
Buy
实体

{{sell.item.image}}
如果
图像
字段与图像名称相同,则可能需要将该字段更改为
图像字段

然后显示图像的代码为:

<img src="{{ sell.item.image.url }}">


(已找到)

您可以访问模板中与
销售
相关的
购买
实体

{{sell.item.image}}
如果
图像
字段与图像名称相同,则可能需要将该字段更改为
图像字段

然后显示图像的代码为:

<img src="{{ sell.item.image.url }}">


(已找到)

不相关,但此
for
循环将很快变糟。也许可以尝试这样的方法:
buys=seals。选择相关(“项目”)。值列表(“项目”,flat=True)
不相关,但这个
for
循环将很快变糟。也许可以这样做:
buys=seals.select_related(“item”).values\u list(“item”,flat=True)
如果
{{sell.item.image]}
处于for循环中,请在视图中的queryset上使用
select_related
。如果
{sell.item.image]}
处于for循环中,请在视图中的查询集上使用
选择\u related
。参考