summaryrefslogtreecommitdiff
path: root/grades/models.py
diff options
context:
space:
mode:
authorPrabhu Ramachandran2018-03-22 18:36:05 +0530
committerGitHub2018-03-22 18:36:05 +0530
commitd4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5 (patch)
tree8a767d224ac6a1688cd3eb301b2ccac40413fc7e /grades/models.py
parent734b221a98745ccb6218f43923731323a265966a (diff)
parentc49550b6793c0481fae08f04c794218513894cc4 (diff)
downloadonline_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.tar.gz
online_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.tar.bz2
online_test-d4f49e8a93ed2ce2e63bd67fa77aa75741c2d6c5.zip
Merge pull request #438 from prathamesh920/Grades
Grades
Diffstat (limited to 'grades/models.py')
-rw-r--r--grades/models.py46
1 files changed, 46 insertions, 0 deletions
diff --git a/grades/models.py b/grades/models.py
new file mode 100644
index 0000000..fcea510
--- /dev/null
+++ b/grades/models.py
@@ -0,0 +1,46 @@
+from django.db import models
+from django.contrib.auth.models import User
+
+
+class GradingSystem(models.Model):
+ name = models.CharField(max_length=255, unique=True)
+ description = models.TextField(default='About the grading system!')
+ creator = models.ForeignKey(User, null=True, blank=True)
+
+ def get_grade(self, marks):
+ ranges = self.graderange_set.all()
+ lower_limits = ranges.values_list('lower_limit', flat=True)
+ upper_limits = ranges.values_list('upper_limit', flat=True)
+ lower_limit = self._get_lower_limit(marks, lower_limits)
+ upper_limit = self._get_upper_limit(marks, upper_limits)
+ grade_range = ranges.filter(lower_limit=lower_limit,
+ upper_limit=upper_limit).first()
+ if grade_range:
+ return grade_range.grade
+
+ def _get_upper_limit(self, marks, upper_limits):
+ greater_than = [upper_limit for upper_limit in upper_limits
+ if upper_limit > marks]
+ if greater_than:
+ return min(greater_than, key=lambda x: x-marks)
+
+ def _get_lower_limit(self, marks, lower_limits):
+ less_than = []
+ for lower_limit in lower_limits:
+ if lower_limit == marks:
+ return lower_limit
+ if lower_limit < marks:
+ less_than.append(lower_limit)
+ if less_than:
+ return max(less_than, key=lambda x: x-marks)
+
+ def __str__(self):
+ return self.name.title()
+
+
+class GradeRange(models.Model):
+ system = models.ForeignKey(GradingSystem)
+ lower_limit = models.FloatField()
+ upper_limit = models.FloatField()
+ grade = models.CharField(max_length=10)
+ description = models.CharField(max_length=127, null=True, blank=True)