由于大多数答案已过时,因此我将尝试在Django 2.2上更新您的
信息-您的应用(帖子,博客,商店等)
1)从模型链接:https : //docs.djangoproject.com/en/2.2/ref/models/meta/
from posts.model import BlogPost
all_fields = BlogPost._meta.fields
#or
all_fields = BlogPost._meta.get_fields()
注意:
all_fields=BlogPost._meta.get_fields()
还将获得一些关系,例如。您无法在视图中显示。
就我而言:
Organisation._meta.fields
(<django.db.models.fields.AutoField: id>, <django.db.models.fields.DateField: created>...
和
Organisation._meta.get_fields()
(<ManyToOneRel: crm.activity>, <django.db.models.fields.AutoField: id>, <django.db.models.fields.DateField: created>...
2)从实例
from posts.model import BlogPost
bp = BlogPost()
all_fields = bp._meta.fields
3)从父模型
假设我们有Post作为父模型,并且您想查看列表中的所有字段,并且使父字段在Edit模式下为只读。
from django.contrib import admin
from posts.model import BlogPost
@admin.register(BlogPost)
class BlogPost(admin.ModelAdmin):
all_fields = [f.name for f Organisation._meta.fields]
parent_fields = BlogPost.get_deferred_fields(BlogPost)
list_display = all_fields
read_only = parent_fields