Djangoadminsite(一)ModelAdminOptions
관리자 관리 인터페이스는 Django의 킬러 애플리케이션입니다. 이는 스키마의 메타데이터를 읽은 다음 웹 사이트 관리자가 웹 사이트에 콘텐츠를 즉시 추가하는 데 사용할 수 있는 강력하고 사용 가능한 인터페이스를 제공합니다.
관리자를 사용하려면 다음 단계를 따르세요.
설정의 INSTALLED_APPS 구성에 'django.contrib.admin'을 추가하세요.
INSTALLED_APPS에 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.messages' 및 'django.contrib.sessions.'가 포함되어 있는지 확인하세요. Django 관리자에게는 이 4개의 Bag이 필요합니다.
'django.contrib.messages.context_PROcessors.messages'를 TEMPLATE_CONTEXT_PROCESSORS에 추가하고 MIDDLEWARE_CLASSES에 'django.contrib.auth.middleware.AuthenticationMiddleware' 및 'django.contrib.messages.middleware.MessageMiddleware'가 포함되어 있는지 확인하세요. (기본적으로 추가됨)
관리자에게 적용해야 할 모델을 결정합니다.
관리자가 필요한 각 앱의 admin.py에 ModelAdmin을 만듭니다.
Model 및 ModelAdmin 등록
from django.contrib import admin
from myproject.myapp.models import Author
class AuthorAdmin(admin.ModelAdmin):
pass
admin.site.register(Author, AuthorAdmin)
URLconf에서 관리자 액세스 구성
from django.contrib import admin
admin.autodiscover()
# 그리고 이 URL 패턴을 포함하세요...
urlpatterns = 패턴('',
# ...
(r'^admin/', include(admin.site.urls) ),
# ...
)
python Manage.py migration을 실행하여 수퍼유저 생성을 알리면 http://127.0.0.1:8000/admin/에 액세스할 수 있습니다.
ModelAdmin 객체
register decorator
register(*models[, site=django.admin.sites.site])
1.7에 새로 추가되었습니다. Model 및 ModelAdmin은 다음과 같이 등록할 수 있습니다:
from django.contrib import admin
from .models import Author
@admin.register(Author)
class AuthorAdmin(admin. ModelAdmin) :
pass
한 번에 여러 모델을 등록할 수 있으며 사용자 정의된 AdminSite를 사용할 수 있습니다:
from django.contrib import admin
from .models import Author, Reader, Editor
from myproject.admin_site import custom_admin_site
@admin.register(Author, Reader, Editor, site=custom_admin_site)
class PersonAdmin(admin.ModelAdmin):
pass
Admin 작동 방식
'django.contrib.admin'이 INSTALLED_APPS에 추가되면 django는 자동으로 각 앱에서 admin.py 모듈을 찾아 가져옵니다.
class apps.AdminConfig
Django 1.7 new.
Django가 시작되면 관리자 기본 AppConfig 클래스가 실행됩니다.
class apps.SimpleAdminConfig
Django 1.7의 새로운 기능.
AdminConfig와 유사하며 autodiscover()를 실행하지 않습니다.
autodiscover()
각 관리자를 가져옵니다. app .py 모듈.
Django 1.7 변경 사항:
이전 버전에서는 각 앱의 admin.py를 찾으려면 urls.py에서 이 메서드를 수동으로 시작해야 했습니다. 1.7 이후에는 AdminConfig가 이 메서드를 자동으로 실행합니다.
사용자 정의된 AdminSite를 사용하는 경우 ModelAdmin의 하위 클래스를 자체 코드로 로드하고 이를 모두 사용자 정의된 AdminSite에 등록해야 합니다. 이 경우 자동 검색()을 중지해야 하며, INSTALLED_APPS의 'django.contrib.admin'을 'django.contrib.admin.apps.SimpleAdminConfig'로 대체하면 됩니다.
ModelAdmin 옵션
actions
관리자 작업 목록
actions_on_top
actions_on_bottom
작업 위치.
date_hierarchy
date_hierarchy를 모델의 DateField 또는 DateTimeField로 설정하여 관리자에서 이 모델에 날짜 계층 구조를 추가하세요.
fields
exclude
는 모델 양식에 표시되는 필드를 결정합니다. 필드에는 포함, 제외 제외가 포함됩니다.
from django.contrib import admin
class AuthorAdmin(admin.ModelAdmin):
fields = ('name', 'title')
class AuthorAdmin(admin) .ModelAdmin):
제외 = ('생년월일',)
같은 줄에 다음 URL 및 제목 필드와 같이 일부 필드를 같은 줄에 배치할 수 있습니다.
class FlatPageAdmin(admin.ModelAdmin):
fields = (('url', 'title'), 'content')
fieldsets
fieldsets는 이중 튜플(이름, field_options), 필드는 블록으로 나눌 수 있습니다:
from django.contrib import admin
class FlatPageAdmin(admin.ModelAdmin):
fieldsets = (
(없음) , {
' 접기',),
'필드': ('enable_comments', 'registration_required', 'template_name')
}),
)
name은 블록의 제목이고 field_options는 사전입니다.
field_options의 키는 다음과 같습니다:
fields
fieldset
{
'fields'에 표시되는 필드 이름 튜플 : (('first_name', 'last_name'), 'address', 'city', 'state'),
}
클래스
필드셋 목록에 추가 제공 CSS 클래스 중.
설명
필드셋 상단에 표시할 수 있는 추가 텍스트입니다.
filter_horizontal
filter_vertical
모델에 ManyToManyField 필드가 있는 경우 filter_horizontal을 사용하며 기존 옵션에서 filter_vertical을 선택할 수 있습니다. 하나는 가로, 하나는 세로입니다.
양식
사용된 양식입니다.
django 가져오기 양식
from django.contrib import admin
from myapp.models import Person
class PersonForm(forms.ModelForm):
class Meta :
모델 = 사람
제외 = ['이름']
class PersonAdmin(admin.ModelAdmin):
제외 = ['나이']
form = PersonForm
충돌이 발생하면 ModelAdmin이 우선적으로 적용됩니다. 위의 예에서는 나이는 제외되지만 이름은 페이지에 표시됩니다.
formfield_overrides
모델 양식 인터페이스에서 일부 필드의 옵션을 재정의하고 일부 특정 유형의 필드에 대해 사용자 정의된 구성 요소를 추가할 수 있습니다.
예를 들어 다음을 수행할 수 있습니다. 자신만의 모델의 TextField 필드 추가 서식 있는 텍스트 편집기 사용:
from django.db import models
from django.contrib import admin
# 사용자 정의 위젯과 모델을 해당 위치에서 가져옵니다. 정의되었습니다
from myapp.widgets import RichTextEditorWidget
from myapp.models import MyModel
class MyModelAdmin(admin.ModelAdmin):
formfield_overrides = {
models.TextField: {' widget': RichTextEditorWidget},
}
list_display
모델의 변경 목록 페이지에 표시할 수 있는 필드 list_display가 설정되지 않은 경우 관리 인터페이스가 자동으로 표시됩니다. 모델의 __unicode__() 결과.
list_display에는 4개의 값이 있습니다:
모델 필드
list_display = ('first_name', 'last_name')
모델을 매개변수로 사용하는 호출 가능한 함수
def upper_case_name(obj):
return ("%s %s" % (obj.first_name, obj.last_name)).upper()
upper_case_name .short_description = '이름'
class PersonAdmin(admin.ModelAdmin):
list_display = (upper_case_name,)
ModelAdmin의 속성, 호출 가능한 함수와 유사
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'
django의 호출 가능 함수
와 유사한 Model의 속성 .db import models
from django.contrib import admin
class Person(models.Model):
name = models.CharField(max_length=50)
birthday = models.DateField( )
defdede_born_in(self):
return self.birthday.strftime('%Y')[:3] + "0's"
decade_born_in.short_description = '탄생 10년'
class PersonAdmin(admin.ModelAdmin):
list_display = ('name', 'decade_born_in')
참고:
필드가 ForeignKey인 경우 표시되는 키의 __unicode__입니다.
ManyToManyField는 지원하지 않습니다
BooleanField인 경우 on/off가 표시됩니다.
제공된 문자열이 Model 또는 ModelAdmin의 메서드이거나 호출 가능한 함수인 경우 Django는 출력을 자동으로 HTML 이스케이프합니다. 이스케이프를 원하지 않으면 메서드의 허용_태그를 True로 설정할 수 있습니다. XSS 사이트 간 공격을 방지하려면 format_html을 사용하여 사용자 입력을 이스케이프 처리해야 합니다.
django.db에서 모델 가져오기
django.contrib에서 관리자 가져오기
django.utils.html에서 import format_html
class Person(models.Model):
first_name = models. CharField(max_length=50)
last_name = models.CharField(max_length=50)
color_code = models.CharField(max_length=6)
def Coloured_name(self):
return format_html( '{1} {2}',
이 🎜>
class PersonAdmin(admin.ModelAdmin):
list_display = ('first_name', 'last_name', 'color_name')
제공된 문자열이 Model 또는 ModelAdmin 또는 호출 가능한 함수를 호출하고 True 또는 False를 반환하는 경우 메서드의 부울 속성을 True로 설정할 수 있습니다. 이런 식으로 켜기 또는 끄기 아이콘이 페이지에 표시됩니다.
django.db에서 모델 가져오기
django.contrib에서 가져오기 관리자
class Person(models.Model):
first_name = models.CharField(max_length=50) birthday = models.DateField()
def Born_in_fifties(self):
return self.birthday.strftime('%Y')[:3] == '195'
Born_in_fifties.boolean = True
class PersonAdmin(admin.ModelAdmin):
list_display = ('name', 'born_in_fifties')
Model의 __str__ 또는 __unicode__ 메서드도
list_display = ('__str__', 'some_other_field')
list_display의 항목이 데이터베이스의 실제 필드가 아닌 경우 이 항목을 기준으로 정렬할 수 없습니다. 그렇지 않으면 이 항목으로 주문할 수 있으며 admin_order_field 속성을 설정하여 이 사실을 지적할 수 있습니다.
from django.db 모델 가져오기
from django.contrib 가져오기 관리자
first_name = models.CharField(max_length=50)
color_code = models.CharField(max_length=6)
def Coloured_first_name(self):
return format_html('{1}',
_tags = 참
color_first_name.admin_order_field = 'first_name'
class PersonAdmin(admin.ModelAdmin):
list_display = ('first_name', 'color_first_name')
colored_first_name으로 정렬하려고 하면 django는 first_name으로 정렬합니다. 역순으로 정렬 가능:
color_first_name.admin_order_field = '-first_name'
list_display의 항목은 속성일 수도 있습니다:
first_name = models.CharField(max_length=50)
last_name = models.CharField(max_length=50)
def my_property(self):
my_property.short_description = "본인의 성명"
full_name = property(my_property)
class PersonAdmin(admin.ModelAdmin):
list_display = ('full_name' ,)
list_display_link
해당 필드는 모드 변경 페이지로 연결됩니다
class PersonAdmin(admin.ModelAdmin):
list_display = (' first_name ', 'last_name', 'birthday')
list_display_links = ('first_name', 'last_name')
list_filter
여기에 포함된 필드는 모델을 필터링하는 필터로 사용될 수 있습니다. 관련 도메인일 수 있습니다.
class PersonAdmin(admin.UserAdmin):
list_filter = ('company__name',)list_max_show_all
모두 표시 페이지의 모델 수 , 저장 200이 누락되었습니다.
list_per_page
각 변경 목록 페이지의 모델 수, 기본값은 100입니다.
list_select_관련
select_관련()과 관련됩니다.
주문
주문.
페이지네이터
에서 사용하는 페이지네이터입니다. 기본 django.core.paginator.Paginator.
prepopulated_fields
미리 채워진 필드입니다.
radio_fields
선택 상자 대신 라디오 버튼을 사용하세요(ForeignKey 또는 선택 옵션이 있는 경우).
class PersonAdmin(admin.ModelAdmin):
radio_fields = {"group": admin.VERTICAL}
raw_id_fields
는 fields , ForeignKey 또는 ManyToManyField에 사용됩니다.
class ArticleAdmin(admin.ModelAdmin):
raw_id_fields = ("newspaper",)
readonly_fields
읽을 수 있고 편집할 수 없는 필드만. 메소드일 수도 있습니다:
from django.contrib import admin
from django.utils.html import format_html_join
from django.utils.safestring import mark_safe
class PersonAdmin( admin.ModelAdmin):
readonly_fields = ('address_report',)
def address_report(self, instance):
# get_full_address()가 문자열 목록을 반환한다고 가정
# 각 줄 주소의 각
# 줄을 줄바꿈으로 구분합니다
return format_html_join(
mark_safe('
'),
((( line,) 라인 입력의 경우 instance.get_full_address()),
) 또는 "이 주소를 확인할 수 없습니다."
# short_description 함수는 모델 필드와 같습니다. verbose_name
address_report.short_description = "Address"
# 이 예에서는 출력에 HTML 태그를 사용했습니다.
address_report.allow_tags = True
add_view()에서 사용하는 템플릿.
change_view()에서 사용하는 템플릿.
에서 사용하는 템플릿 changelist_view() .
delete_view()에서 사용하는 템플릿입니다.
delete_selected 작업 메서드에서 사용하는 템플릿입니다.
history_view()에서 사용하는 템플릿 및 로그입니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









이 기사에서는 HTML을 구문 분석하기 위해 파이썬 라이브러리 인 아름다운 수프를 사용하는 방법을 설명합니다. 데이터 추출, 다양한 HTML 구조 및 오류 처리 및 대안 (SEL과 같은 Find (), find_all (), select () 및 get_text ()와 같은 일반적인 방법을 자세히 설명합니다.

Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

파이썬 객체의 직렬화 및 사막화는 사소한 프로그램의 주요 측면입니다. 무언가를 Python 파일에 저장하면 구성 파일을 읽거나 HTTP 요청에 응답하는 경우 객체 직렬화 및 사태화를 수행합니다. 어떤 의미에서, 직렬화와 사제화는 세계에서 가장 지루한 것들입니다. 이 모든 형식과 프로토콜에 대해 누가 걱정합니까? 일부 파이썬 객체를 지속하거나 스트리밍하여 나중에 완전히 검색하려고합니다. 이것은 세상을 개념적 차원에서 볼 수있는 좋은 방법입니다. 그러나 실제 수준에서 선택한 직렬화 체계, 형식 또는 프로토콜은 속도, 보안, 유지 보수 상태 및 프로그램의 기타 측면을 결정할 수 있습니다.

Python의 통계 모듈은 강력한 데이터 통계 분석 기능을 제공하여 생물 통계 및 비즈니스 분석과 같은 데이터의 전반적인 특성을 빠르게 이해할 수 있도록 도와줍니다. 데이터 포인트를 하나씩 보는 대신 평균 또는 분산과 같은 통계를보고 무시할 수있는 원래 데이터에서 트렌드와 기능을 발견하고 대형 데이터 세트를보다 쉽고 효과적으로 비교하십시오. 이 튜토리얼은 평균을 계산하고 데이터 세트의 분산 정도를 측정하는 방법을 설명합니다. 달리 명시되지 않는 한,이 모듈의 모든 함수는 단순히 평균을 합산하는 대신 평균 () 함수의 계산을 지원합니다. 부동 소수점 번호도 사용할 수 있습니다. 무작위로 가져옵니다 수입 통계 Fracti에서

이 기사는 딥 러닝을 위해 텐서 플로와 Pytorch를 비교합니다. 데이터 준비, 모델 구축, 교육, 평가 및 배포와 관련된 단계에 대해 자세히 설명합니다. 프레임 워크, 특히 계산 포도와 관련하여 주요 차이점

이 튜토리얼은 간단한 나무 탐색을 넘어서 DOM 조작에 중점을 둔 아름다운 수프에 대한 이전 소개를 바탕으로합니다. HTML 구조를 수정하기위한 효율적인 검색 방법과 기술을 탐색하겠습니다. 일반적인 DOM 검색 방법 중 하나는 EX입니다

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.

이 기사는 Python 개발자가 CLIS (Command-Line Interfaces) 구축을 안내합니다. Typer, Click 및 Argparse와 같은 라이브러리를 사용하여 입력/출력 처리를 강조하고 CLI 유용성을 향상시키기 위해 사용자 친화적 인 디자인 패턴을 홍보하는 세부 정보.
