Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用模型表达式将Django模型中的整数和小数相乘_Django_Django Models_Query Expressions - Fatal编程技术网

使用模型表达式将Django模型中的整数和小数相乘

使用模型表达式将Django模型中的整数和小数相乘,django,django-models,query-expressions,Django,Django Models,Query Expressions,我是Django初学者,在我的一个项目中,我制作了以下模型: class Piece(models.Model): order = models.ForeignKey(Order,on_delete=models.CASCADE) coil = models.ForeignKey(Cut_Material ,on_delete=models.CASCADE) piece_length = models.DecimalField(max_digits=4, dec

我是Django初学者,在我的一个项目中,我制作了以下模型:

class Piece(models.Model):
    
    order = models.ForeignKey(Order,on_delete=models.CASCADE)
    coil = models.ForeignKey(Cut_Material ,on_delete=models.CASCADE)
    piece_length = models.DecimalField(max_digits=4, decimal_places=2)
    prime_pieces = models.IntegerField()
    reject_pieces = models.IntegerField()

    def __str__(self):
        return (str(self.piece_length))

    class Meta:
        ordering = ["-order","piece_length"]
我想用
piece\u length
prime\u pieces
相乘,得到运行的仪表,以下是我的解决方案:

解决方案1:

解决方案
Piece.objects.annotation(运行米=(F('Piece\u length')*F('prime\u pieces'))

错误
类型错误:QuerySet.aggregate()接收到非表达式:。

解决方案2

解决方案
Piece.objects.annotation(运行米=(F('Piece\u length')*F('prime\u pieces')),output\u field=FloatField())

错误
类型错误:QuerySet.aggregate()接收到非表达式:。

有人能帮我解决问题吗?

使用:

(添加了格式),您只需尝试创建一个额外的注释
output\u field
,该注释映射到一个
FloatField

这里需要的是一个,
output\u字段=…
ExpressionWrapper
的一个参数:

from django.db.models import ExpressionWrapper

Piece.objects.annotate(
    running_meters=ExpressionWrapper(
        F('piece_length') * F('prime_pieces'),
        output_field=FloatField()
    )
)
从django.db.models导入ExpressionWrapper
工件.objects.annotate(
运行米=表达式包装器(
F(‘工件长度’)*F(‘基本工件’),
输出\字段=浮动字段()
)

)
谢谢,它很有效!
from django.db.models import ExpressionWrapper

Piece.objects.annotate(
    running_meters=ExpressionWrapper(
        F('piece_length') * F('prime_pieces'),
        output_field=FloatField()
    )
)