Курс 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. Атрибуты класса и экземпляра
  2. Аргументы *args и **kwargs
  3. Работа с комплексными числами в Python
  4. Solidity для DeFi Ethereum
  5. Парсинг статей с Newspaper3k
  6. Оболочка Python
  7. Основы Python
  8. Метод get() в Python
  9. Оператор += в Python
  10. Принципы Zen Python
  11. Обработка ошибки IndexError
  12. Получение текущей даты в Python
  13. Распаковка элементов последовательности
  14. Метод index() в Python
  15. Операторы сравнения в Python
  16. Лямбда-функции для min/max
  17. Namedtuple в Python
  18. Гибкие функции Python
  19. Создание namedtuple из словаря
  20. Измерение времени выполнения кода
  21. Замена символов в Python
  22. Работа с асинхронными задачами в Python
  23. Цикл for в Python
  24. Создание таблиц в Python с PrettyTable
  25. Работа с модулем Calendar
  26. Извлечение чисел из текста
  27. Удаление дубликатов из списка с помощью dict.fromkeys
  28. Возведение в квадрат с помощью itertools
  29. Создание объекта времени
  30. Округление чисел с помощью round
  31. Ввод нескольких значений
  32. Импорт модуля из другого каталога
  33. Работа с утверждениями в Python
  34. Встроенные функции Python
  35. Оператор in и not in в Python
  36. Функции высшего порядка в Python
  37. Отправка поздравлений по дню рождения
  38. Обмен значений переменных в Python
  39. Метод join() для объединения строк
  40. Переопределение метода xor в Python
  41. Python Enum Weekday Usage
  42. Избегайте изменяемых аргументов
  43. Установка и использование библиотеки google
  44. Использование функции enumerate()
  45. ROT13 Шифр Цезаря в Python

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