Djangoのadmin管理ツール

12705 ワード

一、基本設定
1,アプリケーション登録
appアプリケーションをバックグラウンド管理に表示するには、admin.pyに登録する必要があります.登録には2つの方法があります
1.1方式一:
from django.contrib import admin
from blog.models import Blog
  
#Blog      
class BlogAdmin(admin.ModelAdmin):
    list_display=('id', 'caption', 'author', 'publish_time')
     
# admin     
admin.site.register(Blog, BlogAdmin)

1.2方式二:装飾器で
from django.contrib import admin
from blog.models import Blog
  
#Blog      
@admin.register(Blog)
class BlogAdmin(admin.ModelAdmin):
    list_display=('id', 'caption', 'author', 'publish_time')

2,adminインタフェースの漢化
デフォルトのadminバックグラウンド管理インタフェースは英語で、settings.pyで設定できます.
  LANGUAGE_CODE='zh-hans'
  TIME_ZONE='Asia/Shanghai'
二、記録リストインタフェースの設定
1、レコードリストの基本設定
from django.contrib import admin
from app01.models import Book
from django.utils.safestring import mark_safe
#Blog @admin.register(Book) class BookAdmin(admin.ModelAdmin):
  def _



  def authors(self,obj):
    return ','.join([obj_author for obj_author in obj.author.all()])
#listdisplay (id Django ) list_display = ('name', 'publish', 'authors', 'pub_date','price') #list_per_page , 100 list_per_page = 50 #ordering , ordering = ('-price',) #list_editable list_editable = ['price'] #fk_fields fk_fields = ('machine_room_id',)
  # list_display_links = ('name', 'pub_date')
  # list_filter =('publish', 'author', ) # search_fields =('name', 'net', 'mark') # date_hierarchy = 'go_time' #  
  
  # select_related
  list_select_related

  #action, action ( )
  def func(self,request,queryset):
    queryset.update(price=100)
  func.short_description=' '
  actions=[func,]

  # HTML
  add_form_template=None
  change_form_template=None
  change_list_template=None
  delete_confirmation_template=None
  delete_selected_confirmation_template=None
  object_history_template=None


 三、adminソースコード解読
1,すべてのappのadmin.pyファイルを起動する
def autodiscover():
    autodiscover_modules('admin', register_to=site)

2、モデルクラスの登録
class BookAdmin(admin.ModelAdmin):      #       
    list_display = ("title",'publishDate', 'price')

admin.site.register(Book, BookAdmin) 
admin.site.register(Publish)

registerメソッドを実行するには、次の手順に従います.
class ModelAdmin:        #   
  
pass
class
AdminSite: def __init__(self): self._registry = {} def register(self, model, admin_class=None, **options): admin_class = admin_class or ModelAdmin self._registry[model] = admin_class(model)
site=AdminSite()

モデルクラスを登録した後、_registry辞書には、モデルクラスをキーとし、クラスオブジェクトを値として構成するキー値ペアが追加されています.
    :
_registry={Book:BookAdmin(Book),Publish:ModelAdmin(Publish)}

3,adminのurl構成
urlpatterns = [
    path('admin/', admin.site.urls),
]
class ModelAdmin():
    @property
    def urls(self):
        return self.get_urls(), None, None
     def get_urls(self):
        temp=[
            path('',self.list_view),
            path('add/',self.add_view),
            re_path('(\d+)/delete/',self.delete_view),
            re_path('(\d+)/edit/',self.edit_view),
        ]
        return temp
    
class AdminSite:
    @property
    def urls(self):
        return self.get_urls(), 'admin', self.name
    def get_urls(self):
        temp=[]
        for model,config_obj in self._registry.items():
            model_name = model._meta.model_name
            app_label = model._meta.app_label
            temp.append(path('%s/%s/'%(app_label,model_name),config_obj.urls))
        return temp

これでurlの2級配布が完了しました