如何在Django中通过选中表单复选框筛选queryset?

2024-06-16 10:11:11 发布

您现在位置:Python中文网/ 问答频道 /正文

我需要根据django形状中标记的复选框更新模型 如何在查询中仅获取部分表字段

“checked”行应该通过queryset更新 型号.py

class moIn(models.Model):
    date = models.DateTimeField(auto_now_add=True, verbose_name='')
    dateUpdate = models.DateTimeField(auto_now=True)
    ts = models.IntegerField(verbose_name='')
    pl = models.IntegerField(verbose_name='')
    rem = models.IntegerField(verbose_name='')
    comment = models.TextField(max_length=200, verbose_name='', blank=True)
    staffer = models.ForeignKey(User, on_delete=models.PROTECT, verbose_name='')
    checked = models.BooleanField(verbose_name='', default=False)
    checkedUser = models.ForeignKey(User, on_delete=models.PROTECT, verbose_name='', blank=True, null=True, related_name='checkedUser')

单击此复选框,您将需要接收数据库记录 forms.py

class checkForm(ModelForm):
    checked = fields.BooleanField(required=False)
    class Meta:
        model = moIn
        fields = {"id", "checked"}

视图.py

def dashboard(request):
    if request.user.groups.filter(name='DashBoardAccess').exists():
        form = checkForm
        f = tableDashFilter(request.GET, queryset=moIn.objects.all())
        if request.method == 'POST':
            form = checkForm(request.POST)
            if form.is_valid():
                tt = form.save(commit=False)
                data = form.cleaned_data
                field = data['checked']=True
                f.qs.filter(checked=field).update(checked=True, checkedUser=request.user)
                return HttpResponse('ok')
        else:
            context = {
                'filter': f,
                'form': form
            }
            return render(request, 'dashboard/index.html', context)
    else:
        raise Http404()

在粗体行中,您只需要获取标记复选框的行

f.qs.filter(checked=field).update(checked=True, checkedUser=request.user)


Tags: namepyformfalsetrueverbosemodelsrequest
1条回答
网友
1楼 · 发布于 2024-06-16 10:11:11

可以使用“.values()”获取queryset的所有字段,要将其与foreignKey一起使用,需要显式指定模型字段:

f = tableDashFilter(request.GET, queryset=moIn.objects.values('id','date','ts','pl','rem','comment','checked','staffer__username','checkedUser__username'))

输入的“值”,也将通过以下方式获得: 由于可以有多个值(标记的复选框),因此将有一个“.getlist”

checkID = request.POST.getlist('checked')

查询集筛选器:

f.qs.filter(id__in=checkID).update(checked=True, checkedUser=request.user)

在html模板中,通过循环,迭代并插入模型id的输入值

相关问题 更多 >