django-mutant在django-admin中创建模型

时间:2012-10-25 14:05:56

标签: python django dynamic django-models models

我开始尝试django-mutant 0.0.2(在django 1.4.2上),但由于缺乏文档,我几乎无处可去。我通过项目描述理解的方式我可以用它来动态创建我的模型,所以我想我可以用django-admin接口连接它,所以我可以创建模型并在那里定义它的所有字段。我看到了其他一些替代方案,例如django-eavdynamo,Will Hardy的dynamic-models等,但听起来这是迄今为止最好的实现,所以我想我应该使用它。

我把它放在settings.py

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.admin',
    'south',
    'polymodels',
    'mutant',
    'mutant.contrib.boolean',
    'mutant.contrib.temporal',
    'mutant.contrib.file',
    'mutant.contrib.numeric',
    'mutant.contrib.text',
    'mutant.contrib.web',
    'mutant.contrib.related',
    'dynamodels'   # this is the name of my testapp
)

我打开了django-mutant的来源以确定我应该做什么,我认为将mutant.models.ModelDefinitionmutant.models.FieldDefinition导入我的admin.py并注册就足够了他们,所以我尝试了这个:

from django.contrib import admin

from mutant import models


class ModelDefinitionAdmin(admin.ModelAdmin):
    pass

admin.site.register(models.ModelDefinition, ModelDefinitionAdmin)


class FieldDefinitionAdmin(admin.ModelAdmin):
    pass

admin.site.register(models.FieldDefinition, FieldDefinitionAdmin)

在syncdb之后,我让它运行了,我的管理界面中有一个“突变”部分,里面有“模型定义”和“字段”。我成功添加了一个模型,但我无法指定INSTALLED_APPS列表中的任何appname。添加一个字段失败,因为它的Model def参数我选择了之前创建的模型(它是列表中唯一的模型),我确实为Content type选择了“整数字段定义”。点击保存按钮给了我这个:

NotImplementedError at /admin/mutant/fielddefinition/add/

No exception supplied
...
...
/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/field/__init__.py in save
        return super(FieldDefinition, self).save(*args, **kwargs) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_polymodels-1.0.1-py2.6.egg/polymodels/models.py in save
        return super(BasePolymorphicModel, self).save(*args, **kwargs) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/model/__init__.py in save
        self.model_def.model_class(force_create=True) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/model/__init__.py in model_class
            model_class = self._create_model_class(existing_model_class) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/model/__init__.py in _create_model_class
        attrs = self.get_model_attrs(existing_model_class) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/model/__init__.py in get_model_attrs
                            for f in self.fielddefinitions.select_subclasses())) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/model/__init__.py in <genexpr>
                            for f in self.fielddefinitions.select_subclasses())) ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/field/__init__.py in field_instance
        cls = self.get_field_class() ...

/home/user/dev/virenvs/dynamicmodels/lib/python2.6/site-packages/django_mutant-0.0.2-py2.6.egg/mutant/models/field/__init__.py in get_field_class
            raise NotImplementedError 

所以它可能不是我应该定义我的字段(甚至是模型?)的方式..在项目的页面上有一个片段,其中FieldDefinition类的子类,创建一个DateFieldDefinition,如果我把那个片段进入我的models.py并在我的管理员中注册该课程,我可以成功添加任何类型的字段。这是否意味着我必须子类化我想要使用的所有字段类型才能在管理员中创建它们?当我以这种方式创建它们时,它们实际上是否与我的模型绑定?是否有某个工作示例至少显示基础知识? 对不起,这是我能想到的最短版本,任何建议都会受到赞赏。

更新 我在指定我正在尝试的版本时犯了一个错误,我得到了最新开发版本的NotImplementedError(顺便说一下也是0.0.2),但是当我尝试从PyPi获得的真实0.0.2与dev,我收到了一个没有错误消息的表单错误,但是肯定会在验证时失败。所以一般来说我并不接近解决方案。

UPDATE2: 我在管理员中动态注册了突变体的基本字段类型,现在我可以使用此管理片段添加/更改/删除模型和字段:

from django.contrib import admin

from mutant import models

for field_type in models.FieldDefinitionBase._field_definitions.values():
    attrs = {'model': field_type}
    FieldDefAdmin = type('{0}Admin'.format(field_type.__name__),
                         (admin.ModelAdmin,),
                         attrs)
    admin.site.register(field_type, FieldDefAdmin)


class ModelDefinitionAdmin(admin.ModelAdmin):
    model = models.ModelDefinition

admin.site.register(models.ModelDefinition, ModelDefinitionAdmin)

但是,当我从mysql控制台检查数据库中的实际数据时,我的表在数据库中不存在。有突变体的表,它们包含关于我的模型和我的字段的条目,但我认为一旦动态模型类被构造,它也将被原样写入数据库。

UPDATE3: 实际上我错了,表格在我的数据库中找到,它只是以“mutant_”为前缀,所以我不认识它就在那里。看起来这将是一个有效的方法来使用它,虽然要使用一个体面的用户友好的界面来操作它将需要更多的工作。

1 个答案:

答案 0 :(得分:5)

好的,我很抱歉,但是我太忙了(而且可能更懒)完成像我说的那样体面的应用程序。但是为了帮助至少一点,我创建了一篇关于该主题的脏博客文章,并为突变体添加了一个示例CRUD应用程序,但要注意,它真的非常基本,只是为了演示启动和运行的前几个步骤。 / p>

http://integricho.github.io/2013/07/22/mutant-introduction/

https://github.com/integricho/mutant-sample-app