django 网站上的教程显示了模型的以下代码:
The tutorial on the django website shows this code for the models:
from django.db import models
class Poll(models.Model):
question = models.CharField(max_length=200)
pub_date = models.DateTimeField('date published')
class Choice(models.Model):
poll = models.ForeignKey(Poll)
choice = models.CharField(max_length=200)
votes = models.IntegerField()
现在,这些属性中的每一个都是类属性,对吧?因此,该类的所有实例都应共享相同的属性.稍后,他们展示了这段代码:
Now, each of those attribute, is a class attribute, right? So, the same attribute should be shared by all instances of the class. A bit later, they present this code:
class Poll(models.Model):
# ...
def __unicode__(self):
return self.question
class Choice(models.Model):
# ...
def __unicode__(self):
return self.choice
它们是如何从类属性转变为实例属性的?我是不是把类属性弄错了?
How did they turn from class attributes into instance attributes? Did I get class attributes wrong?
看看django/db/models.py下的Model类.在那里,类属性通过类似的方式转换为实例属性
Have a look at the Model class under django/db/models.py. There the class attributes are turned to instance attributes via something like
setattr(self, field.attname, val)
人们可能会推荐整个文件(ModelBase 和 Model 类)作为元类的优秀实践示例.
One might recommend the whole file (ModelBase and Model class) as an excellent hands-on example on metaclasses.
这篇关于Django 模型与Python 类属性的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
python:不同包下同名的两个模块和类python: Two modules and classes with the same name under different packages(python:不同包下同名的两个模块和类)
配置 Python 以使用站点包的其他位置Configuring Python to use additional locations for site-packages(配置 Python 以使用站点包的其他位置)
如何在不重复导入顶级名称的情况下构造python包How to structure python packages without repeating top level name for import(如何在不重复导入顶级名称的情况下构造python包)
在 OpenShift 上安装 python 包Install python packages on OpenShift(在 OpenShift 上安装 python 包)
如何刷新 sys.path?How to refresh sys.path?(如何刷新 sys.path?)
分发带有已编译动态共享库的 Python 包Distribute a Python package with a compiled dynamic shared library(分发带有已编译动态共享库的 Python 包)