Курс 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. Путь к интерпретатору Python
  3. Управление памятью в Python
  4. Проверка элементов списка условием
  5. Работа с библиотекой requests
  6. Работа с deque из collections
  7. Управление фоновыми задачами в Python
  8. Метод сравнения объектов в Python
  9. Метод split() для разделения строк
  10. Переопределение метода xor в Python
  11. Поиск шаблона в строке
  12. Python Enum Weekday Usage
  13. Combobox в Tkinter
  14. Взаимодействие с sys
  15. Измерение времени выполнения кода в Python
  16. Комментарии в Python
  17. Генераторы в Python
  18. Подсчет элементов в Python
  19. Оператор «and» в Python
  20. Замена символов в строке
  21. Цикл for в Python
  22. Инверсия списка и строки в Python
  23. Функция reduce() в Python
  24. Progress с библиотекой tqdm
  25. Цикл while в Python
  26. Python: возвращение нескольких значений
  27. Переопределение метода sub
  28. Роль запятой в Python
  29. Выбор редактора кода.
  30. Получение срезов итераторов
  31. Применение функции к списку
  32. Форматирование данных с помощью pprint
  33. Подсчет элементов с помощью Counter
  34. Метод splitlines() для разделения строк
  35. Удаление файлов в Python
  36. Создание пользовательской коллекции в Python
  37. Построение графиков в терминале с bashplotlib
  38. Оператор space-invader
  39. Оценка точности модели
  40. Область видимости переменных
  41. Проверка типов с помощью isinstance
  42. Работа с кортежами
  43. Генераторы списков
  44. Метод rsub в Python: расширение функциональности вычитания
  45. Функции в Python
  46. Создание и инициализация объектов
  47. Работа с JSON в Python

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