模型方法

为了给你的对像添加一个行级功能,那就定义一个自定义方法。 有鉴于manager经常被用来用一些整表操作(table-wide),模型方法应该只对特殊模型实例起作用。

这是一项在模型的一个地方集中业务逻辑的技术。

最好用例子来解释一下。 这个模型有一些自定义方法:

  1. from django.contrib.localflavor.us.models import USStateField
  2. from django.db import models
  3. class Person(models.Model):
  4. first_name = models.CharField(max_length=50)
  5. last_name = models.CharField(max_length=50)
  6. birth_date = models.DateField()
  7. address = models.CharField(max_length=100)
  8. city = models.CharField(max_length=50)
  9. state = USStateField() # Yes, this is U.S.-centric...
  10. def baby_boomer_status(self):
  11. "Returns the person's baby-boomer status."
  12. import datetime
  13. if datetime.date(1945, 8, 1) <= self.birth_date <= datetime.date(1964, 12, 31):
  14. return "Baby boomer"
  15. if self.birth_date < datetime.date(1945, 8, 1):
  16. return "Pre-boomer"
  17. return "Post-boomer"
  18. def is_midwestern(self):
  19. "Returns True if this person is from the Midwest."
  20. return self.state in ('IL', 'WI', 'MI', 'IN', 'OH', 'IA', 'MO')
  21. def _get_full_name(self):
  22. "Returns the person's full name."
  23. return u'%s %s' % (self.first_name, self.last_name)
  24. full_name = property(_get_full_name)

例子中的最后一个方法是一个property。 想了解更多关于属性的信息请访问http://www.python.org/download/releases/2.2/descrintro/#property

这是用法的实例:

  1. >>> p = Person.objects.get(first_name='Barack', last_name='Obama')
  2. >>> p.birth_date
  3. datetime.date(1961, 8, 4)
  4. >>> p.baby_boomer_status()
  5. 'Baby boomer'
  6. >>> p.is_midwestern()
  7. True
  8. >>> p.full_name # Note this isn't a method -- it's treated as an attribute
  9. u'Barack Obama'