Курс 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. Курс Data Scientist в медицине
  2. Удаление элементов во время итерации
  3. Экспорт функций в Python
  4. Замена переменных в Python
  5. Генерация резюме в Gensim
  6. Метод join() для объединения элементов строки
  7. Работа с парами ключ-значение
  8. Numpy: объединение массивов
  9. Списковое включение в Python
  10. Импорт модулей в Python 3.12
  11. Округление банкира в Python
  12. Измерение времени выполнения в Python
  13. Отображение HTML кода в Python
  14. Поиск уникальных и повторяющихся элементов
  15. Управление памятью в Python
  16. Подписка на SelectelNews в Twitter
  17. Добавление элементов в список: append() vs extend()
  18. Транспонирование 2D-массива с помощью zip
  19. Возведение в квадрат с помощью itertools
  20. Очистка списка от False, None, 0, «»
  21. Руководство по Pymorphy2
  22. Метод get() в Python
  23. Настройка Cron
  24. Новшества Flask 2.0
  25. Работа с файлами в Python
  26. Поиск наиболее частого элемента
  27. Метод splitlines() для разделения строк
  28. Извлечение аудио из видео
  29. Ноутбуки AMD Ryzen ™ 4000: мощность и эффективность
  30. Python enumerate() функции
  31. Шаблоны и наследование в Flask
  32. Счетчик ссылок в Python
  33. Удаление символов новой строки в Python.
  34. Создание вложенных циклов for
  35. Структуры данных в Python
  36. Работа с YAML в Python: PyYAML.
  37. Функция с *args.
  38. Получение комбинаций в Python
  39. Функции с дополнением
  40. Списки: объединение, изменение
  41. Метод __irshift__ для Python
  42. Работа с deque в Python

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