OrderFilter является django -фильтром. Экспорт работает, но у меня есть только заголовок ... когда я удаляю request.get.get, у меня извлекаются все данные, поэтому я предполагаю, что где-то в моем запросе get есть проблема. Не могли бы вы помочь мне, пожалуйста
Шаблон Views.py
def Order(request):
filter= OrderFilter(request.GET, queryset=Order.objects.all())
orders= filter.qs.order_by('-Date')
"""
Don't work
Category_query = request.GET.get('Category')
qs = Order.objects.filter(Category= Category_query)
"""
if request.GET.get('Export') == 'Export':
response = HttpResponse(content_type='application/ms-excel')
response['Content-Disposition'] = 'attachment; filename="data.xlsx"'
wb = xlwt.Workbook(encoding='utf-8')
ws = wb.add_sheet('Data')
row_num = 0
font_style = xlwt.XFStyle()
font_style.font.bold = True
columns = ['Date', 'Category', 'Item']
for col_num in range(len(columns)):
ws.write(row_num, col_num, columns[col_num], font_style)
font_style = xlwt.XFStyle()
rows=qs.values_list('Date', 'Category', 'Item')
for row, rowdata in enumerate(rows):
row_num += 1
for col, val in enumerate(rowdata):
if isinstance(val,datetime.date):
val = val.strftime('%d/%m/%Y')
ws.write(row_num, col, val, font_style)
wb.save(response)
return response
return render(request, 'template.html',{'orders':orders,'filter': filter})
. html
<form method="get">
{{filter.form}}
<button class="btn btn-primary" type="submit">Search</button>
</form>
<form method="GET" >
<button class="btn btn-warning" type="submit" value="Export" name="Export"> Export</button>
</form>