Курс 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. Основные методы NumPy
  3. Доступ к локальным переменным
  4. Работа с контекстными менеджерами
  5. Именование переменных в Python
  6. Копирование списков в Python
  7. Функция rsplit() в Python
  8. Преобразование строк в числа с плавающей запятой
  9. Глубокое копирование объектов
  10. Установка и использование Python-dateutil
  11. Генерация UUID в Python
  12. Передача аргументов в Python
  13. Преобразование регистра символов
  14. Атрибуты класса и экземпляра
  15. Любовь к Python
  16. Модуль inspect
  17. Работа с CSV файлами в Python
  18. Работа с итераторами через срезы
  19. Преобразование списков в словарь
  20. Отслеживание выполнения программы с библиотекой tqdm
  21. Работа с буфером обмена на Python
  22. Инициализация переменных
  23. Применение промокода в Много лосося
  24. Генератор данных в Keras
  25. Метод enumerate() в Python
  26. Оператор space-invader
  27. Создание спинбокса в tkinter
  28. Блок else в Python
  29. Роль object и type в Python
  30. Красивый вывод списка
  31. Конкатенация строковых литералов
  32. Извлечение статей с newspaper3k
  33. Аннотации типов в Python
  34. Определение объема памяти объекта
  35. Математические функции в Python
  36. Функции all и any в Python
  37. Структурирование именованных констант
  38. Concrete Paths в Python
  39. Вычисление фазы комплексного числа
  40. Оператор assert в Python
  41. Метод join() для объединения элементов строки
  42. Создание namedtuple списком полей
  43. Создание копии списка в Python
  44. Генерация тестовых данных с factory_boy
  45. Закрытие файла в Python
  46. Работа с GitHub в Telegram
  47. Python Метод sleep() времени
  48. Работа с пользовательским вводом

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