13. Django Basic django 페이지
view
from django.shortcuts import render,HttpResponse
# Create your views here.
from app01.models import *
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
def index(request):
'''
:
Booklist=[]
for i in range(100):
Booklist.append(Book(title="book"+str(i),price=30+i*i))
Book.objects.bulk_create(Booklist)
'''
'''
:
book_list=Book.objects.all()
paginator = Paginator(book_list, 10)
print("count:",paginator.count) #
print("num_pages",paginator.num_pages) #
print("page_range",paginator.page_range) #
page1=paginator.page(1) # 1 page
for i in page1: # 1
print(i)
print(page1.object_list) # 1
page2=paginator.page(2)
print(page2.has_next()) #
print(page2.next_page_number()) #
print(page2.has_previous()) #
print(page2.previous_page_number()) #
#
#page=paginator.page(12) # error:EmptyPage
#page=paginator.page("z") # error:PageNotAnInteger
#page = page_obj.page(-1) #That page number is less than 1 , EmptyPage , , 1
'''
book_list=Book.objects.all()
paginator = Paginator(book_list, 10) # 10
page = request.GET.get('page',1) # url http://127.0.0.1:8000/ /?page=1
currentPage=int(page)
try:
print(page)
book_list = paginator.page(page)
except PageNotAnInteger:
book_list = paginator.page(1)
except EmptyPage:
book_list = paginator.page(paginator.num_pages)
return render(request,"index.html",{"book_list":book_list,"paginator":paginator,"currentPage":currentPage})
index.html:
Title
{% for book in book_list %}
- {{ book.title }} -----{{ book.price }}
{% endfor %}
확장성
from django.core.paginator import Paginator,PageNotAnInteger,EmptyPage
def show(request):
book_objs = models.Book.objects.all()
page_obj = Paginator(book_objs,1)
print(' ',page_obj.count)
print(' ',page_obj.num_pages)
print(' ',page_obj.page_range)
page1 = page_obj.page(1)
for i in page1:
print(i)
print(page1.object_list)
page2 = page_obj.page(2)
print(page2.has_previous())
print(page2.has_next())
print(page2.next_page_number())
print(page2.previous_page_number())
# page = page_obj.page(-1)
page_num = request.GET.get('page',1)
try:
current_page_num = int(page_num)
page_num_data = page_obj.page(current_page_num)
except PageNotAnInteger:
current_page_num = 1
page_num_data = page_obj.page(current_page_num)
except EmptyPage:
current_page_num = page_obj.num_pages
page_num_data = page_obj.page(current_page_num)
except Exception:
current_page_num = 1
page_num_data = page_obj.page(current_page_num)
if page_obj.num_pages > 11: # , 11, , 11 , 5 , 5
if current_page_num - 5 < 1:
pageRange = range(1,12)
elif current_page_num + 5 > page_obj.num_pages:
pageRange = range(page_obj.num_pages-10,page_obj.num_pages+1)
else:
pageRange = range(current_page_num - 5,current_page_num + 6)
else:
pageRange = page_obj.page_range
book_objs = page_num_data
return render(request,'show.html',{'book_objs':book_objs,'current_page_num':current_page_num,'page_obj':page_obj,'pageRange':pageRange})
show.html
{% load static %}
Title
model.py 파일 내용:
from django.db import models
# Create your models here.
class Author(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=32)
age=models.IntegerField()
authorDetail=models.OneToOneField(to="AuthorDetail",to_field="nid")
def __str__(self):
return self.name
class AuthorDetail(models.Model):
nid = models.AutoField(primary_key=True)
birthday=models.DateField()
telephone=models.BigIntegerField()
addr=models.CharField( max_length=64)
class Publish(models.Model):
nid = models.AutoField(primary_key=True)
name=models.CharField( max_length=32)
city=models.CharField( max_length=32)
email=models.EmailField()
def __str__(self):
return self.name
class Book(models.Model):
nid = models.AutoField(primary_key=True)
title = models.CharField( max_length=32)
publishDate=models.DateField()
price=models.DecimalField(max_digits=5,decimal_places=2)
publish=models.ForeignKey(to="Publish",to_field="nid")
authors=models.ManyToManyField(to='Author',)
def __str__(self):
return self.title
2. 사용자 정의 페이지
데이터베이스에 데이터가 매우 많으면, 우리는 보통 앞쪽 페이지에서 페이지를 나누어 보여 준다.
페이지의 데이터는 전방 페이지에서 실현할 수도 있고 후단 페이지에서 실현할 수도 있다.
백엔드에서 페이지를 나누는 원리는 매번 한 페이지의 데이터만 요청하는 것이다.
준비 작업
스크립트를 사용하여 테스트 데이터를 대량으로 만듭니다(다음 코드를 bulk create.py 파일에 저장하여 Django 프로젝트의 루트 디렉터리에 저장하고 직접 실행하면 됩니다.):
import os
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "about_orm.settings")
import django
django.setup()
from app01 import models
bulk_obj = (models.Publisher(name=' {} '.format(i)) for i in range(300))
models.Publisher.objects.bulk_create(bulk_obj) # ,
다음 버전의 페이지 나누기를 보십시오.
def publisher_list(request):
# URL
try:
current_page = int(request.GET.get('page'))
except Exception as e:
# 1
current_page = 1
#
total_count = models.Publisher.objects.count()
#
per_page = 10
#
total_page, more = divmod(total_count, per_page)
if more:
total_page += 1
# ( , )
max_show = 11
half_show = max_show // 2
#
if total_page <= max_show: #
page_start = 1
page_end = total_page
elif current_page + half_show >= total_page: #
page_end = total_page
page_start = total_page - max_show
elif current_page - half_show <= 1: #
page_start = 1
page_end = max_show
else: #
page_start = current_page - half_show
page_end = current_page + half_show
#
data_start = (current_page-1) * per_page
data_end = current_page * per_page
publisher_list = models.Publisher.objects.all()[data_start:data_end]
#
page_html_list = []
page_html_list.append('')
page_html = "".join(page_html_list)
return render(request, "publisher_list.html", {"publisher_list": publisher_list, "page_html": page_html})
class Pagination(object):
""" (Bootstrap )"""
def __init__(self, current_page, total_count, base_url, per_page=10, max_show=11):
"""
:param current_page:
:param total_count:
:param base_url: URL
:param per_page: , 10
:param max_show: , 11
"""
try:
self.current_page = int(current_page)
except Exception as e:
# 1
self.current_page = 1
#
self.per_page = per_page
#
total_page, more = divmod(total_count, per_page)
if more:
total_page += 1
self.total_page = total_page
# ( , )
self.max_show = max_show
self.half_show = max_show // 2
self.base_url = base_url
@property
def start(self):
return (self.current_page-1) * self.per_page
@property
def end(self):
return self.current_page * self.per_page
def page_html(self):
#
if self.total_page <= self.max_show: #
page_start = 1
page_end = self.total_page
elif self.current_page + self.half_show >= self.total_page: #
page_end = self.total_page
page_start = self.total_page - self.max_show
elif self.current_page - self.half_show <= 1: #
page_start = 1
page_end = self.max_show
else: #
page_start = self.current_page - self.half_show
page_end = self.current_page + self.half_show
#
page_html_list = []
page_html_list.append('')
return "".join(page_html_list)
def publisher_list(request):
# URL
current_page = int(request.GET.get('page'))
# len(models.Publisher.objects.all())
total_count = models.Publisher.objects.count()
page_obj = Pagination(current_page, total_count, request.path_info)
data = models.Publisher.objects.all()[page_obj.start:page_obj.end]
page_html = page_obj.page_html()
return render(request, "publisher_list.html", {"publisher_list": data, "page_html": page_html})
django 내장 페이지 분할기 페이지 추가
from django.shortcuts import render
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
L = []
for i in range(999):
L.append(i)
def index(request):
current_page = request.GET.get('p')
paginator = Paginator(L, 10)
# per_page:
# count:
# num_pages:
# page_range: , : (1,10),(1,200)
# page: page
try:
posts = paginator.page(current_page)
# has_next
# next_page_number
# has_previous
# previous_page_number
# object_list
# number
# paginator paginator
except PageNotAnInteger:
posts = paginator.page(1)
except EmptyPage:
posts = paginator.page(paginator.num_pages)
return render(request, 'index.html', {'posts': posts})
{% for item in posts %}
- {{ item }}
{% endfor %}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.