paginator class

내부적으로, pagination의 모든 함수는 Paginator class를 사용

QuerySet 분할 부터 Page 객체까지 모든 작업을 한다.

>>> from django.core.paginator import Paginator
>>> objects = ['john', 'paul', 'george', 'ringo']
>>> p = Paginator(objects, 2)   # 한 페이지에 아이템 갯수

>>> p.count #전체 갯수
>>> p.num_pages #페이지 갯수
>>> type(p.page_range)
<class 'range'>

>>> page1 = p.page(1)   # 첫 번째 페이지 객체
>> page1.object_list
['john', 'paul']

>>> page2 = p.page(2)   # 두 번째 페이지 객체
>>> page2.object_list
['george', 'ringo']

>>> page2.has_next() # 객체의 다음 페이지가 있는지 
>>> page2.has_previous() # 객체의 이전 페이지가 있는지
>>> page2.has_other_pages() # 다른 페이지가 있는지
>>> page2.next_page_number() # 다음 페이지 번호
>>> page2.previous_page_number() # 이전 페이지 번호
>>> page2.start_index() # 시작점
>>> page2.end_index() # 끝점


Paginating a ListView

django.views.generic.list.ListView는 paginate을 builtin으로 제공한다.

from django.views.generic import ListView

from myapp.models import Contact

class ContactList(ListView):
    paginate_by = 2
    model = Contact


<div class="pagination">
    <span class="step-links">
        

        <span class="current">
            Page  of .
        </span>

        
    </span>
</div>


Using paginator in a view function

from django.core.paginator import Paginator
from django.shortcuts import render

from myapp.models import Contact

def listing(request):
    contact_list = Contact.objects.all()
    paginator = Paginator(contact_list, 25) # Show 25 contacts per page.

    page_number = request.GET.get('page')
    page_obj = paginator.get_page(page_number)
    return render(request, 'list.html', {'page_obj': page_obj})


출처

https://docs.djangoproject.com/en/3.1/topics/pagination/