2011-09-06 11 views
8

Sto tentando di costruire dinamicamente alcune classi che sono sottoclassi dei modelli di django.Modello. Il mio codice è simile al seguente:Python: manca l'attributo di classe __module__ quando si usa type()?

MyModel = type('MyModel', (models.Model,), { 
    'field': models.BooleanField() 
    }) 

Quando Django prova a caricare questo, ha pronunciato la seguente eccezione:

Traceback (most recent call last): 
    File "/usr/lib/python2.7/site-packages/django/core/management/commands/runserver.py", line 88, in inner_run 
    self.validate(display_num_errors=True) 
    File "/usr/lib/python2.7/site-packages/django/core/management/base.py", line 249, in validate 
    num_errors = get_validation_errors(s, app) 
    File "/usr/lib/python2.7/site-packages/django/core/management/validation.py", line 36, in get_validation_errors 
    for (app_name, error) in get_app_errors().items(): 
    File "/usr/lib/python2.7/site-packages/django/db/models/loading.py", line 146, in get_app_errors 
    self._populate() 
    File "/usr/lib/python2.7/site-packages/django/db/models/loading.py", line 61, in _populate 
    self.load_app(app_name, True) 
    File "/usr/lib/python2.7/site-packages/django/db/models/loading.py", line 78, in load_app 
    models = import_module('.models', app_name) 
    File "/usr/lib/python2.7/site-packages/django/utils/importlib.py", line 35, in import_module 
    __import__(name) 
    File "/home/user/project/app/models.py", line 221, in <module> 
    'field': models.BooleanField() 
    File "/usr/lib/python2.7/site-packages/django/db/models/base.py", line 38, in __new__ 
    module = attrs.pop('__module__') 
KeyError: '__module__' 

Sembra una classe costruito utilizzando type() non sta ottenendo il membro __module__ che è presente per la classe definita con class. Cosa sta succedendo qui?

risposta

13

Può essere metaclasses è la scelta migliore per le esigenze rispetto a basso livello type()?

Ma nella maggior parte dei casi è possibile utilizzare __name__ come un valore per __module__ come

MyModel = type('MyModel', (models.Model,), { 
    'field': models.BooleanField(), 
    '__module__': __name__, 
}) 

Django utilizza __module__ rapporto qualità-determinare quali Django app possiede questo modello, in modo modelli in my_app1/models.py conterranno my_app1.models e Django sa che i modelli da quel file | modulo appartiene all'applicazione my_app1.

Problemi correlati