장고 관리자 화면 커스터마이징

Pywiki
Sam (토론 | 기여)님의 2021년 11월 4일 (목) 13:53 판 (새 문서: ==관리자 화면 커스터마이징== 기본적으로 클래스를 새로이 지정해준 후 등록하는 방식을 거친다. 각 앱의 admin.py에서 수정.<syntaxhighlight la...)
(차이) ← 이전 판 | 최신판 (차이) | 다음 판 → (차이)
둘러보기로 가기 검색하러 가기

1 관리자 화면 커스터마이징

기본적으로 클래스를 새로이 지정해준 후 등록하는 방식을 거친다. 각 앱의 admin.py에서 수정.

from django.contrib import admin
from .models import Question #모델을 불러오고

@admin.register(Question)  # 모델 등록
class QuestionAdmin(admin.ModelAdmin):  # 관리자기능을 위한 클래스
    필요한 내용.  # 그 내용은 아래 표에서 찾자.
    
admin.site.register(Question,QuestionAdmin)  # QuestionAdmin의 등록을 추가한다.
의도 설명 코드(QuestionAdmin 안에 추가한다.)
나타나는 필드 순서 변경하기 앱이름/admin.py 파일의 클래스에서 필드 순서 변경
fields=['필드명', '필드명2',...]#필드명의 순서에 따라 정렬
디스플레이항목조정(위와 다를 게 무엇일까;;) 관리자화면 목록에 나오는 항목들을 조정하고 싶을 때가 있다. 다음과 같이 list_display 변수를 지정하는 것으로 가능하다.
list_display=('모델의 하위속성1', '모델의 하위속성2',...)
클릭으로 수정화면 넘어가기. 관리자화면에서 보는 내용을 누르면 편집화면으로 들어가게 할 속성을 지정할 수 있다. list_display_links = ['하위속성', '하위속성2']
필터 해당 속성에 필터를 걸면 모델의 필드에 맞춰 자동으로 필터를 생성한다.(날짜의 경우, 오늘, 최근7일 등)
list_filter=['필터를 걸 속성']
모델검색
  1. 검색창을 만들어주고,
  2. 여러 필드를 기입해 검색의 범위를 지정할 수 있다.
search_fields = ['subject'] #검색할 필드를 넣어준다.
객체순서 배치하기 장고가 기본으로 사용하는 정렬값으로 배치할 수 있다.
ordering = ['subject', '-subject2'] #검색할 필드를 넣어준다.
#-는 거꾸로 정렬함을 의미.

1.1 수정화면 조정

디테일을 볼 수 있는 내용. 수정화면에서 모델의 속성을 그룹화 하여 수정화면을 편집할 수 있다.

from django.contrib import admin
from .models import Question #모델을 불러오고

class QuestionAdmin(admin.ModelAdmin):#관리자기능을 위한 클래스
    fieldsets=[
        ('나타낼그룹명', {'fields':['해당항목']}),
        (None, {'fields':['해당항목1', 해당항목2]}),
        ]
admin.site.register(Question,QuestionAdmin) #QuestionAdmin의 등록을 추가한다.

1.2 하위객체와의 관계

의도 설명 코드
하위객체 한 화면에서 보기 연결된 하위객체를 한 화면에서 보고 조작할 수 있다면 관리가 수월해진다.
from django.contrib import admin
from .models import Question, Answer  # 모델을 불러오고

class AnsewerInline(admin.StackedInline):
    model=Answer
    extra=3  # 기존에 있던 외에 추가할 수 있는 칸. 몇 개를 만들 것인가?

class QuestionAdmin(admin.ModelAdmin):
    inlines=[AnsewerInline]  # 위에서 작성한 클래스를 넣어준다.
admin.site.register(Question,QuestionAdmin)  # QuestionAdmin의 등록을 추가한다.
표로 간결하게 보기 하지만, 위처럼 쓰면 관리자페이지가 너무 길어져 불편하기도 하다. 이럴 땐 객체들을 테이블 형태로 만들어주어야 하는데, 다음과 같이 부모클래스만 바꾸어주면 된다.
class AnsewerInline(admin.TabularInline):
    model=Answer
    extra=3

2 관련 에러

2.1 페이지가 이상해지는 경우

장고 버전업이 되면서 관리자페이지에 새로운 기능이 추가되곤 하는데, 이 때 CSS나 다른 것들도 바뀌곤 한다. 하여, 관리자페이지가 망가지는 경우엔 장고 버전업 후에 collectstatic 명령도 같이 해주어야 정상적으로 반영된다.