Курс 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. Именованные аргументы в Python
  2. Путь к интерпретатору Python
  3. Списки в Python
  4. Удаление файлов с shutil.os.remove()
  5. Циклы в Python
  6. Операции с датами в Python
  7. Просмотр атрибутов и методов класса
  8. Удаление ресурса в Python
  9. Математические функции в Python
  10. Метод remove() для удаления элемента из списка
  11. Объявление переменных в Python
  12. Метод __index__ в Python
  13. Гибкие функции Python
  14. Генераторы в Python
  15. Функция format() в Python
  16. Декораторы в Python
  17. Создание и удаление объектов
  18. Изменение переменной в Python: nonlocal
  19. Метод Enumerate() для списков
  20. Оптимизация памяти в Python
  21. Глобальные переменные в Python
  22. Объединение списков в Python.
  23. Оператор «or» в Python
  24. Объединение Python и Shell
  25. Метод join() для объединения строк
  26. Форматирование строк с помощью f-строк
  27. Импорт с альтернативным именем
  28. Работа с типами данных в Python с помощью pydantic.
  29. Получение обратного списка чисел
  30. Инверсия списка/строки в Python
  31. Участие в сообществе @selectel
  32. Именование переменных в Python
  33. Создание пар из последовательностей
  34. split() — разделение строки
  35. Типы возвращаемых значений в Python
  36. Функции в Python
  37. Принципы LSP и ISP в Python
  38. Основы слова
  39. Функция с **kwargs в Python
  40. Операции с комплексными числами
  41. Конструктор в Python
  42. Работа с файловой системой в Python
  43. Аннотации типов в Python
  44. Расчет времени выполнения
  45. Объединение строк с помощью метода join
  46. Псевдонимы в Python

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