Создание динамических URL в Flask с использованием url_for()

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Функция url_for() во Flask используется для создания динамических URL. Чтобы сгенерировать URL, вы вызываете url_for и передаете ей имя функции-обработчика и параметры в формате ключ-значение:

Python
Скопировать код
@app.route('/post/<int:post_id>')  
def show_post(post_id):
    return 'Пост номер {}'.format(post_id)

dynamic_url = url_for('show_post', post_id=42)

После выполнения этого кода, переменная dynamic_url будет содержать строку '/post/42', которая соответствует уникальному URL данного поста.

Кинга Идем в IT: пошаговый план для смены профессии

Поддержание актуальности при помощи url_for()

Использование url_for() во Flask помогает вашему прокту оставаться "DRY" (т.е. "Don't Repeat Yourself" – принцип разработки программного обеспечения, обозначающий "не повторяйся") и улучшает поддерживаемость кода. Вместо того чтобы жестко прописывать URL в шаблонах, можно вернуться к использованию функции url_for():

Python
Скопировать код
<a href="{{ url_for('show_post', post_id=post.id) }}">Читать пост</a>

Задание приоритетов маршрутов

Flask предоставляет возможность устанавливать приоритетность маршрутов при использовании url_for(). Это может быть полезно, когда есть несколько похожих маршрутов, и вам нужно гарантированный выбор определенного маршрута на основании динамических параметров.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Управление статическими файлами

Функция url_for() позволяет генерировать URL для статических файлов, делая ссылки на них удобными для управления:

Python
Скопировать код
url_for('static', filename='style.css')

Визуализация

Давайте предложим, что Flask – это услужливый консьерж в роскошной гостинице, а динамические URL – это номера этой гостиницы:

Markdown
Скопировать код
Гость = Пользователь запроса 🔑
Консьерж (🛎️): "Добро пожаловать в гостиницу Flask. Чем я могу быть полезен вам сегодня?"

Теперь рассмотрим, как функционирует url_for():

Python
Скопировать код
url_for('floor', room='deluxe')  # 🛎️: Проводит гостя в его люкс номер

Итог: 🔗 динамическая ссылка – /floor/deluxe

Markdown
Скопировать код
До: Гость (🔑) --- "Я хотел бы заселиться в свой люкс номер."
После: Гость (🔑) 🛎️🔗 `/floor/deluxe`

Консьерж (Flask) надежно ведет гостя (пользователя) в его номер (к нужному URL), основываясь на его запросе.

Ключевые аргументы + url_for() = чудо динамических маршрутов

Функция url_for() превращает ключевые аргументы в части пути URL, открывая возможности для динамической маршрутизации в приложении:

Python
Скопировать код
url_for('add_post', category='news', sort='latest')  # Публикация последних новостей
url_for('remove_post', post_id=123)  # Заметили ошибку в посте №123? Удаляем его!

Правила работы с переменными

Flask позволяет управлять переменными маршрута, предлагая фильтровать аргументы в зависимости от их типа данных:

Python
Скопировать код
@app.route('/user/<int:user_id>')  
def show_user(user_id):
    # ...

Вариации маршрутов во Flask

Flask даёт вам возможность управлять различными вариантами маршрутов. Вместо того чтобы создавать каждый путь вручную, позвольте Flask сделать это за вас:

Python
Скопировать код
@app.route('/post/view/<post_id>')  # Чтобы посмотреть пост
@app.route('/post/edit/<post_id>')  # Чтобы редактировать пост
def post_action(post_id, action):
    # Логика просмотра или редактирования поста. У Flask всегда есть решение.
    ...

Обработка ошибок и лучшие практики

При использовании url_for(), убедитесь, что ваши функции представления правильно обрабатывают переменные пути. Кроме того, логичное именование функций и конечных точек окажется очень полезным.

Обработка ошибок генерации URL

Если url_for() не может сгенерировать URL, она возбудит исключение BuildError. Оберните вызовы в блок try-except, чтобы избежать нежелательных сюрпризов:

Python
Скопировать код
try:
    url_for('undefined_endpoint')
except BuildError:
    # Здесь вы справитесь с трудностями
    ...

Единообразие в названиях

Правильное именование в контексте Flask делает код более читаемым и понятным. Следуйте принципу простоты и логичности:

Python
Скопировать код
@app.route('/item/<item_id>/update')  
def update_item(item_id):
    # ...

Простота — залог успеха

Создавайте динамические URL такими, чтобы они были понятны и доступны для лучшего пользовательского опыта. Более подробную информацию о работе со шаблонами в Flask вы можете найти в документации.

Полезные материалы

  1. API — Документация по Flask (2.1.x)
  2. Подробное руководство по Flask, часть V: Авторизация пользователей – miguelgrinberg.com
  3. Уроки Flask #10 – Структура и использование нескольких файлов Python – YouTube
  4. 4. Веб-формы – Разработка веб-приложений с Flask, 2-е издание
  5. Создание веб-API на Python и Flask | Историк программирования
  6. Первые шаги — Официальная документация Flask (2.1.x)
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Что делает функция url_for() в Flask?
1 / 5