Обеспечение пользователя эффективной навигацией по большим наборам данных является ключевым для безупречного пользовательского опыта. Пагинация и сортировка – это две фундаментальные функции, которые позволяют пользователям эффективно взаимодействовать с данными. В этой статье мы рассмотрим реализацию функций пагинации и сортировки в веб-приложениях, построенных с использованием Python и FastAPI.

Понимание пагинации

Пагинация включает в себя разделение большого набора данных на более мелкие, управляемые порции или страницы. Это позволяет пользователям пошагово навигировать по данным, уменьшая время загрузки и улучшая общую производительность. Обычно пагинация включает функции, такие как указание количества элементов на странице и навигацию между страницами.

Реализация в FastAPI

FastAPI, благодаря своим асинхронным возможностям и простым в использовании функциям, упрощает реализацию пагинации. Для активации вам потребуется обрабатывать параметры, такие как номер страницы и размер страницы, в ваших API-конечных точках. Использование параметров запроса удобно для управления клиентами.

from fastapi import FastAPI, Query

from typing import Optional

app = FastAPI()

@app.get("/items/")

async def read_items(page: int = Query(1, gt=0), size: int = Query(10, gt=0)):

# Логика для извлечения элементов из базы данных на основе параметров

# Пример: items = fetch_items(page, size)

return {"page": page, "size": size, "items": items}

Сортировка данных

Сортировка позволяет пользователям упорядочивать данные на основе указанных критериев, таких как алфавитный порядок, числовые значения или временные метки. ФастАПИ поддерживает сортировку путем включения параметров запроса для указания поля сортировки и порядка (по возрастанию или убыванию).

@app.get("/items/")

async def read_items(sort_by: Optional[str] = None):

# Логика для извлечения элементов из базы данных и применения сортировки

# Пример: items = fetch_items_sorted(sort_by)

return {"sorted_by": sort_by, "items": items}

Комбинирование пагинации и сортировки

Интеграция пагинации и сортировки повышает удобство использования за счет предоставления гибкости при изучении данных. Для объединения этих функций требуется обработка параметров в конечных точках API.

@app.get("/items/")

async def read_items(page: int = Query(1, gt=0), size: int = Query(10, gt=0), sort_by: Optional[str] = None):

# Логика для извлечения элементов из БД

items = fetch_items_with_pagination_and_sorting(page, size, sort_by)

return {"page": page, "size": size, "sorted_by": sort_by, "items": items}

Создание функционального проекта

Для демонстрации реализации пагинации и сортировки в функциональном проекте FastAPI давайте создадим API для управления коллекцией книг. Мы позволим пользователям пагинировать список книг и сортировать его по названию или году издания.

Настройка проекта

  • Убедитесь, что у вас установлены Python и pip на вашей системе.
  • Установите библиотеки с помощью pip:
pip install fastapi uvicorn
  • Создайте новый каталог для вашего проекта и перейдите в него:
mkdir fastapi_pagination_sorting

cd fastapi_pagination_sorting
  • Внутри каталога проекта создайте файл с именем main.py и вставьте следующий код:
from fastapi import FastAPI, Query

from typing import Optional

app = FastAPI()

# Мок базы данных книг

books_db = [

{"title": "Python Crash Course", "author": "Eric Matthes", "year": 2019},

{"title": "Fluent Python", "author": "Luciano Ramalho", "year": 2015},

{"title": "Clean Code", "author": "Robert C. Martin", "year": 2008},

{"title": "The Pragmatic Programmer", "author": "Andrew Hunt, David Thomas", "year": 1999},

# Добавьте больше книг при необходимости

]

@app.get("/books/")

async def read_books(page: int = Query(1, gt=0), size: int = Query(10, gt=0), sort_by: Optional[str] = None):

# Применяем пагинацию

start_index = (page - 1) * size

end_index = start_index + size

paginated_books = books_db[start_index:end_index]

# Применяем сортировку, если указана

if sort_by:

paginated_books = sorted(paginated_books, key=lambda x: x.get(sort_by, 0))

return {"page": page, "size": size, "sort_by": sort_by, "books": paginated_books}
  • Сохраните файл main.py.

Запуск проекта

  • Откройте терминальное окно и перейдите в каталог с main.py.
  • Запустите сервер с помощью Uvicorn:
uvicorn main:app --reload
  • После запуска сервера перейдите по адресу http://localhost:8000/docs в вашем веб-браузере, чтобы получить доступ к Swagger UI.
  • Теперь вы можете взаимодействовать с API, чтобы получить пагинированные и отсортированные данные о книгах.

Пример использования

  • Чтобы получить первую страницу книг с 2 элементами на странице, отсортированными по названию:
http://localhost:8000/books/?page=1&size=2&sort_by=title
  • Чтобы получить вторую страницу книг с 3 элементами на странице, отсортированными по году издания:
http://localhost:8000/books/?page=2&size=3&sort_by=year

Заключение

Интеграция функций пагинации и сортировки повышает удобство использования и эффективность веб-приложений. Благодаря интуитивному фреймворку FastAPI и универсальности Python реализация этих функций становится простой. Следуя рекомендациям, представленным в этой статье, разработчики могут предоставить пользователям возможность безупречно перемещаться по большим наборам данных, обеспечивая приятный пользовательский опыт.