Курс Python → Обмен данными с asyncio.Queue

Asyncio.Queue предоставляет удобный способ обмена данными между асинхронными задачами в Python. Он позволяет одной задаче помещать данные в очередь, а другой задаче забирать их для обработки. Это особенно полезно в случаях, когда необходимо организовать взаимодействие между разными частями программы, работающими параллельно.

Для использования asyncio.Queue необходимо создать объект класса asyncio.Queue(). Затем асинхронные задачи могут использовать методы put() для добавления элементов в очередь и get() для извлечения элементов из очереди. Кроме того, можно использовать методы task_done() для уведомления о завершении обработки элемента и join() для ожидания завершения обработки всех элементов очереди.


import asyncio

async def producer(queue):
    for i in range(5):
        await queue.put(i)
        print(f'Producer put: {i}')
    await queue.put(None)

async def consumer(queue):
    while True:
        data = await queue.get()
        if data is None:
            break
        print(f'Consumer got: {data}')
        queue.task_done()

async def main():
    queue = asyncio.Queue()
    producer_task = asyncio.create_task(producer(queue))
    consumer_task = asyncio.create_task(consumer(queue))
    await asyncio.gather(producer_task, consumer_task)
    await queue.join()

asyncio.run(main())

В приведенном примере мы создаем две асинхронные задачи — producer, который помещает числа от 0 до 4 в очередь, и consumer, который извлекает и печатает эти числа. Когда producer завершает свою работу, он помещает значение None в очередь, чтобы consumer мог завершить свою работу. Мы используем asyncio.gather() для запуска обеих задач параллельно и await queue.join() для ожидания завершения обработки всех элементов очереди.

Твои коллеги будут рады, поделись в

Автор урока

Дмитрий Комаровский
Дмитрий Комаровский

Автоматизация процессов
в КраснодарБанки.ру

Другие уроки курса "Python"

  1. Переопределение метода delitem в Python
  2. Оператор объединения словарей
  3. Метод title() в Python
  4. Работа со словарями Python
  5. Объединение множеств в Python
  6. Проверка запуска скрипта или импорта модуля
  7. Проверка файла .py на синтаксис.
  8. Профилирование кода
  9. Вставка переменных в шаблоны Flask
  10. JSON-esque в Python
  11. Защита данных в Python
  12. Поиск простых чисел
  13. Сортировка с параметром key
  14. Проверка надежности пароля на Python
  15. Создание веб-приложения с Flask
  16. Генератор надежных паролей
  17. Генераторы данных
  18. Преобразование регистра символов
  19. Удаление элементов из списка
  20. Запрос DELETE с библиотекой requests
  21. Работа с прокси в Python
  22. Метод join() для объединения элементов строки
  23. Асинхронное выполнение задач в Python
  24. Установка максимального количества цифр
  25. Округление банкира в Python
  26. Прокачанный трейсинг ошибок
  27. Объединение списков в Python
  28. Структура данных deque в Python
  29. Просмотр атрибутов и методов класса
  30. Декораторы в Python
  31. Импорт модулей в Python 3.12
  32. Проверка вхождения подстроки
  33. Переопределение метода __or__()
  34. Обход словаря в Python
  35. Навыки Python: строки, типы данных
  36. Создание множества в Python
  37. Генераторы в Python
  38. Создание вложенного генератора
  39. Метод bool() в Python
  40. Установка и использование Logzero
  41. Colorama: окрашивание текста в Python
  42. Получение текущей даты и времени
  43. Работа с дробями в Python
  44. Метод rsub для пользовательских чисел
  45. Подробная информация о %pinfo
  46. Идентификатор объекта в Python

Marketello читают маркетологи из крутых компаний