我遇到了有关猴子修补Django的帖子:
from django.contrib.auth.models import User User.add_to_class('openid', models.CharField(max_length=250,blank=True)) def get_user_name(self): if self.first_name or self.last_name: return self.first_name + " " + self.last_name return self.username User.add_to_class("get_user_name",get_user_name)
我知道这不是理想的选择,最好User通过单独的模型添加字段和函数Profile。
User
Profile
话虽如此,我只想了解这将如何工作:
我将把monkey补丁代码放在哪里?
代码何时运行-仅运行一次?每个Python解释器启动一次?每个请求一次?
大概我仍然需要更改数据库架构。因此,如果我放下桌子User运行./manage.py syncdb,会syncdb“知道”是否已添加新字段User吗?如果没有,如何更改架构?
./manage.py syncdb
syncdb
您可以将其放置在任何位置,但通常会在设置文件(甚至是urlconf)中看到这种链接。您可以在任何地方发出信号的地方也可能合适。这段代码实际上应该稍微聪明一些- 通常文件导入不止一次,而且您无能为力,因此,如果尝试多次运行这样的代码,可能会遇到问题。
对于每个python进程,该代码至少需要执行一次。
是的,您需要手动更改数据库。Syncdb 可能 不会捕获更改(我没有仔细研究代码),但是可能在某些地方可以放置代码。
您似乎已经知道这是一件可怕的事情,绝不应该在真正的代码中完成,因此我不会为这一点感到lab惜。除了在将来的Django版本中可能无法使用的代码之外,执行此类操作是一种在代码中生成真正难以发现的错误的绝妙方法。
另外,它不适用于您应该使用的South。