0

您好我有以下型号

class Student(models.Model):
    student_id = models.CharField(max_length=3, unique=True)
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=40)
    gender = models.CharField(max_length=1)
    teacher = models.ForeignKey(Teacher)


    def maths_cal_1(self):
        if self.student_model.filter(test__test_name__iexact="maths"):
            return self.student_model.s1- self.student_model.start


class Test(models.Model):
    test_name = models.CharField(max_length=40)
    test_out_of = models.IntegerField(null=True, blank=True)

    CHOICE = ( 
        (u'ENG', u'English'), 
        (u'MTS', u'Maths'),
        )
    KLA = models.CharField(max_length=10, choices=CHOICE)


class Display(models.Model):
    full_name = models.ForeignKey(Student, related_name='student_model')  
    test = models.ForeignKey(Test)
    start = models.CharField(max_length=10, null=True, blank=True)
    s1 = models.CharField(max_length=10, null=True, blank=True)

我不能锻炼的是如何根据在显示模型中的 start 和 s1 字段中输入的数字即时计算简单的数学运算。
我已经尝试使用“maths_cal_1”方法进行此操作,但是当我尝试在模板中呈现结果时,我会得到错误或空白,具体取决于我将方法放入的模型。问题是我相信,每个学生对象都有很多测试. 我似乎无法正确计算所需测试并返回结果。在这种情况下,我想为每个学生的数学测试对象返回计算 s1-start 字段。如何即时为每个学生的每个单独的测试模型进行这些计算?谢谢。

更新:工作代码:

    def maths_cal_1(self):
    cal_list = []

    for tname in ['Maths']:
        try:
            maths_test = self.student_model.get(test__test_name__iexact=tname)
            result = int(maths_test.s1) - int(maths_test.start)

            if result:
                cal_list.append(result)
            else:
                cal_list.append("")
        except (Display.DoesNotExist, ValueError):
            cal_list.append("")

    return cal_list
4

1 回答 1

0

你在正确的轨道上,但你实际上需要得到过滤器的结果,而不是仅仅检查它的存在。

try:
    maths_test = self.student_model.get(test__test_name__iexact="maths")
    result = maths_test.s1 - maths_test.start
except Display.DoesNotExist:
    result = None

return result

(请注意,还有一个问题,因为s1start都是 char 字段:从另一个中减去一个不会给您任何有用的东西。不确定您在这里真正打算做什么。您可能需要将其转换为所需的类型。你能提供样本数据和期望的结果吗?)

于 2012-10-01T10:15:57.600 回答