1π
β
If the ratio
depends entirely on the Function
and Fraction
, it makes not much sense to store this. Then you can just implement this as a propery, like:
class Function(models.Model):
name = models.CharField(max_length=200)
def evaluate(self, x):
if self.name == 'x':
return 4 * x
return x
def __str__(self):
return str(self.name)
class Fraction(models.Model):
fraction = models.DecimalField(max_digits=5, decimal_places=2)
def __str__(self):
return str(self.fraction)
class Project(models.Model):
func = models.ForeignKey(Function, on_delete=models.SET_NULL, null=True)
fraction = models.ForeignKey(Fraction, on_delete=models.SET_NULL, null=True)
@property
def ratio(self):
if self.func is not None and self.fraction is not None:
return self.func.evaluate(self.fraction.fraction)
It will thus determine the ratio by fetching the Function
object, and calling .evaluate(β¦)
. In case the name is x
, it will return the value times four, otherwise it will return the value itself.
0π
Assuming that Function
s names are unique:
project = Project.objects.get(func__name='x')
return project.fraction.fraction * project.ratio
π€Yevhen Kuzmovych
0π
Just to add to the other answers, you can use pythonβs operator library to perform the operations and insert them into a dict. I would suggest combining this with choices
on your name field β though note the choice cannot be an operator function but a string value.
import operator
FUNCTIONS = {
'+': operator.add,
'-': operator.sub,
'*': operator.mul,
'/': operator.truediv
}
class Function(models.Model):
name = models.CharField(max_length=200)
def __str__(self):
return str(self.name)
def evaluate(self, a, b)
op = FUNCTIONS.get(self.name)
if op:
return op(a, b)
return None
π€0sVoid
- [Answered ]-Running a linux subprocess in python with sudo
- [Answered ]-DjangoCMS: How to create a placeholder within a plugin
- [Answered ]-ManyToManyField not saving correctly
- [Answered ]-How to put an object model that has a link as an attribute in a table cell in django
- [Answered ]-ModelForm with overrides throwing ValueError
Source:stackexchange.com