Django如何根据数据时间字段限制下拉菜单中的外键选择

2024-10-05 11:40:31 发布

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


我有在数据库中添加数据的表单,我想限制下拉菜单中的外键选择。必须限制在我的finishDate字段中。如果finishDate是今天之前的日期(例如,今天是21-08-2016,finishDate是30-06-2013),那么我不想显示finishDate的外键值。最简单的方法是什么?我在这方面比较新,所以我需要帮助。在

在模型.py在

class Account(models.Model):
     startDate = models.DateField(verbose_name="Start")
     finishDate = models.DateField(verbose_name="Finish")

     def __str__(self):
         return 'A{}'.format(self.id)

 class Net(models.Model):
     date = models.DateTimeField(default=datetime.now())
     MB = models.IntegerField(validators=[MinValueValidator(1)],default=randint(100,2000))
     idAccount = models.ForeignKey(Account, on_delete=models.CASCADE, verbose_name="Account")

     def __str__(self):
         return 'Record {}'.format(self.datum)

在表单.py在

^{pr2}$

在视图.py在

@login_required(login_url="/accounts/login/")
def net(request):
    if request.method == 'POST':

        form = NetForm(request.POST)

        if form.is_valid():
            internet = form.save()
            return HttpResponseRedirect('/')

    else:
        form = NetForm()

    return render(request, 'project/Net.html', {'form': form})

非常感谢!在


Tags: namepyselfform表单verbosemodelreturn
1条回答
网友
1楼 · 发布于 2024-10-05 11:40:31

您可以在__init__中过滤它

import datetime

def NetForm(forms.ModelForm):
    #...fields
    def __init__(self, *args, **kwargs):
        super(NetForm, self).__init__(*args, **kwargs)
        # Now set the queryset...
        self.fields['idAccount'].queryset = Account.objects.filter(finishDate__gte=datetime.datetime.now())

相关问题 更多 >

    热门问题