I created a django template with the following model
Models.py
class MaterialRequest(models.Model):
owner = models.ForeignKey(Client, on_delete=models.CASCADE, related_name='allotment_sales')
product1 = models.CharField(max_length=500,default=0,blank=True,null=True)
product1_quantity = models.IntegerField(default=0,blank=True,null=True)
product2 = models.CharField(max_length=500,default=0, blank=True,null=True)
product2_quantity = models.IntegerField(default=0,blank=True,null=True)
product3 = models.CharField(max_length=500,default=0, blank=True,null=True)
product3_quantity = models.IntegerField(default=0,blank=True,null=True)
product4 = models.CharField(max_length=500,default=0, blank=True,null=True)
product4_quantity = models.IntegerField(default=0,blank=True,null=True)
product5 = models.CharField(max_length=500,default=0, blank=True,null=True)
product5_quantity = models.IntegerField(default=0,blank=True,null=True)
product6 = models.CharField(max_length=500,default=0, blank=True,null=True)
product6_quantity = models.IntegerField(default=0,blank=True,null=True)
product7 = models.CharField(max_length=500,default=0, blank=True,null=True)
product7_quantity = models.IntegerField(default=0,blank=True,null=True)
product8 = models.CharField(max_length=500,default=0, blank=True,null=True)
product8_quantity = models.IntegerField(default=0,blank=True,null=True)
and I tried displaying this data on the template using this view
def load_salesorder(request):
so_id = request.GET.get('sales_order')
s_o = MaterialRequest.objects.filter(pk=so_id)
print("kits=========",s_o)
return render(request, 'allotment_so.html', {'sales_order': s_o})
HTML
<table class="table table-bordered">
<thead>
<tr>
<th>Product Short Codes</th>
<th>Product Quantity</th>
</tr>
</thead>
<tbody>
<div class="table-container">
{% for i in sales_order %}
<tr>
<td class="align-middle">{{ i.product1 }}</td>
<td class="align-middle">{{ i.product1_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product2 }}</td>
<td class="align-middle">{{ i.product2_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product3 }}</td>
<td class="align-middle">{{ i.product3_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product4 }}</td>
<td class="align-middle">{{ i.product4_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product5 }}</td>
<td class="align-middle">{{ i.product5_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product6 }}</td>
<td class="align-middle">{{ i.product6_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product7 }}</td>
<td class="align-middle">{{ i.product7_quantity }}</td>
</tr>
<tr>
<td class="align-middle">{{ i.product8 }}</td>
<td class="align-middle">{{ i.product8_quantity }}</td>
</tr>
{% endfor %}
</tbody>
</table>
But the problem with is that it also shows the None values of ORM whereas I just want to show the fields that consists the data and leave out the blank values. How can I fix this and also is there a better way to do this ?