Django admin无法找到models.CharField的子类

0 投票
1 回答
665 浏览
提问于 2025-04-18 08:42

我正在为一个Django项目扩展AbstractUser模型,想要添加几个字段,这些字段应该自动填充,包括一个唯一的字符串和创建、修改的时间戳。

我使用了django-model-utils这个包里的字段来处理创建和修改时间,并根据相同的原则自己做了一个自定义字段来存储代码。

但是在Django的管理后台似乎找不到这些字段。

这些字段在其他地方都能正常工作,唯独在Django管理后台不行。

以下是代码的基本结构:

models.py from django.contrib.auth.models import AbstractUser

from model_utils import Choices
from model_utils.fields import AutoCreatedField, AutoLastModifiedField

from .fields import CoombaCodeField



class CoombaUser(AbstractUser):
    # class CoombaUser(models.Model):
    # Timestamp. Created timestamp is suppled by AbstractUser, as date_joined
    modified = AutoLastModifiedField(_('modified'))

    # string identifer, used in referrals
    coomba_code = CoombaCodeField()

fields.py

from django.db import models, OperationalError

from core.keyGenerators import ShortKeyGenerator, KeyGenerator

from .settings import COOMBA_CODE_COUNTER_KEY, COOMBA_CODE_COUNTER_MINIMUM

# Impossible to call code accessing databases before databases are created.
# Code below moves database call to first use.

coomba_code_generator = None


def get_key():
    global coomba_code_generator
    if(coomba_code_generator is None):
        coomba_code_generator = ShortKeyGenerator(
            charset=KeyGenerator.CHARSET_FULL,
            counter_key=COOMBA_CODE_COUNTER_KEY,
            smallest_allowed_value=COOMBA_CODE_COUNTER_MINIMUM
        )
    key = coomba_code_generator.get_key()
    return key


class CoombaCodeField(models.CharField):

    def __init__(self, *args, **kwargs):
        kwargs.setdefault('editable', False)
        kwargs.setdefault('default', get_key)
        kwargs.setdefault('max_length', 30)
        super(CoombaCodeField, self).__init__(*args, **kwargs)

admin.py from django.contrib import admin

from .models import CoombaUser


def full_name(user):
    return (user.first_name + " " + user.last_name)


class CoombaUserAdmin(admin.ModelAdmin):

    list_display = ("email", full_name, "date_joined")
    fieldsets = (
        ("CoombaUser", {
            'fields': (
                "email",
                ("first_name", "last_name"),
                "nickname",
                "coomba_code",
                "social_security_number",
                "gender",
                "date_of_birth",
                "account_status",
                "last_login",
            ),
        }),
    )

admin.site.register(CoombaUser, CoombaUserAdmin)

错误信息:

Environment:


Request Method: GET
Request URL: http://127.0.0.1:8000/admin/coombaUsers/coombauser/1/

Django Version: 1.6.5
Python Version: 2.7.6
Installed Applications:
('django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.sites',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django.contrib.admin',
 'core',
 'coombaUsers',
 'allauth',
 'allauth.account',
 'allauth.socialaccount',
 'allauth.socialaccount.providers.google',
 'allauth.socialaccount.providers.linkedin',
 'djangular',
 'localflavor',
 'parsley',
 'crispy_forms',
 'south',
 'django_coverage')
Installed Middleware:
('django.middleware.common.CommonMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.locale.LocaleMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware')


Traceback:
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\core\handlers\base.py" in get_response
  112.                     response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\contrib\admin\options.py" in wrapper
  432.                 return self.admin_site.admin_view(view)(*args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\utils\decorators.py" in _wrapped_view
  99.                     response = view_func(request, *args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\views\decorators\cache.py" in _wrapped_view_func
  52.         response = view_func(request, *args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\contrib\admin\sites.py" in inner
  198.             return view(request, *args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\utils\decorators.py" in _wrapper
  29.             return bound_func(*args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\utils\decorators.py" in _wrapped_view
  99.                     response = view_func(request, *args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\utils\decorators.py" in bound_func
  25.                 return func(self, *args2, **kwargs2)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\db\transaction.py" in inner
  371.                 return func(*args, **kwargs)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\contrib\admin\options.py" in change_view
  1206.         ModelForm = self.get_form(request, obj)
File "C:\Users\Sverker\.virtualenvs\coomba\lib\site-packages\django\contrib\admin\options.py" in get_form
  531.                              % (e, self.__class__.__name__))

Exception Type: FieldError at /admin/coombaUsers/coombauser/1/
Exception Value: Unknown field(s) (coomba_code) specified for CoombaUser. Check fields/fieldsets/exclude attributes of class CoombaUserAdmin.

1 个回答

1

我不确定这样做是否能解决你的错误,但你为什么要在:

def full_name(user):
    ...

外面定义:

class CoombaUserAdmin(admin.ModelAdmin):
    ....

你是怎么把用户对象传递给 full_name() 的?

我会这样做:

class CoombaUserAdmin(admin.ModelAdmin):
    list_display = ("email", "full_name", "date_joined")

    def full_name(self, obj):
        return u'%s %s' % (obj.first_name, obj.last_name)
    full_name.short_description = "Full Name"    

可以参考这个链接:https://docs.djangoproject.com/en/dev/ref/contrib/admin/#django.contrib.admin.ModelAdmin.list_display

文档中的例子:

class PersonAdmin(admin.ModelAdmin):
    list_display = ('upper_case_name',)

    def upper_case_name(self, obj):
        return ("%s %s" % (obj.first_name, obj.last_name)).upper()
    upper_case_name.short_description = 'Name'

撰写回答