嗨,这是我正在使用的模型
从 django.db 导入模型 从 users.models 导入 CustomUser
class Project(models.Model):
id = models.AutoField(primary_key=True)
user = models.ForeignKey(CustomUser, on_delete=models.PROTECT, editable=False)
name = models.CharField(max_length=20, editable=False)
total = models.DecimalField(max_digits=6, decimal_places=2, editable=False)
created = models.DateTimeField(auto_now_add=True, editable=False, null=False, blank=False)
def __str__(self):
return self.name
该类由使用此视图的 HTML 表单填充:
def homepage(request):
if request.method == "POST":
project = Project()
name = request.POST.get('name')
total = request.POST.get('total')
created = datetime.datetime.now()
user = request.user
project.user = user
project.name = name
project.total = total
project.created = created
project.save()
#return HttpResponse(reverse("homepage.views.homepage"))
return render(request, 'homepage.html')
else:
return render(request, 'homepage.html')
所以我在我的应用程序中添加了一个自定义标签,这是一个功能
@register.filter
def monthlyTotal(user):
this_month = now().month
return Project.objects.filter(
created__month=this_month,
user=user
).aggregate(
sum_total=Sum('total')
)['sum_total']
我在模板中这样称呼标签
<p>Total monthly sales = {{ user.username|monthlyTotal }}</p>
但是我收到一条错误消息,提示字段 ID 需要一个数字,但得到了 'grandmaster',这是我的测试用户的名称,他有多个项目对象。如果我切换到 user.id,我没有收到错误,但它显示 None,这是有道理的,因为当我在管理员中查看我的项目部分时,字段用户由用户名而不是 id 填充,因此不会有 user=id 的项目