Курс 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. JSON в Python: модуль, dump, dumps, load
  2. Переменные в Python
  3. Работа с аргументами командной строки
  4. Работа с collections в Python.
  5. Counter() — подсчет элементов
  6. Разница между датами
  7. Получение текущей даты в Python
  8. Возврат нескольких значений из функции
  9. Фильтрация последовательности
  10. Итерация по итерируемым объектам
  11. Разделение функций на этапы
  12. Подписка на @SelectelNews
  13. Преобразование Word в PDF с Spire.Doc
  14. Список переменных с %who
  15. Библиотека sh: использование команд bash в Python
  16. Метод lt для сортировки объектов
  17. Генераторы в Python
  18. Работа с YAML в Python: PyYAML.
  19. Функция enumerate в Python
  20. Визуализация пропусков данных
  21. Распаковка аргументов в Python
  22. Тип данных TypeVarTuple
  23. Функции в Python: создание и вызов
  24. Деление в Python
  25. Удаление элементов из списка в Python
  26. Создание списка через итерацию
  27. Упрощенный вывод данных в Python
  28. Лямбда-функции в defaultdict
  29. Выражения-генераторы в Python
  30. CLI-инструмент howdoi
  31. Обработка StopIteration в Python
  32. Расчет времени выполнения
  33. Библиотека schedule: планировщик задач
  34. Работа с изменяемыми списками
  35. Метод ifloordiv для пользовательских классов
  36. Преобразование данных в Python
  37. Принципы Zen of Python
  38. Генераторы в Python
  39. Возведение в квадрат с помощью itertools
  40. Улучшение читаемости кода в Python
  41. Глобальные переменные в Python
  42. Генераторы по генератору
  43. Отправка HTTP-запросов с User-Agent
  44. Обход дочерних элементов BeautifulSoup
  45. Основные методы NumPy

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