Курс 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. Работа с YAML в Python
  3. Обмен значений переменных в Python
  4. Метод pos в Python
  5. Проверка типов с помощью isinstance
  6. None в Python: использование и особенности
  7. Удаление знаков препинания в Python
  8. Декораторы в Python
  9. Сортировка и обратный порядок
  10. Округление в Python
  11. Генерация резюме в Gensim
  12. Преобразование списка в словарь через генератор
  13. Избегайте пустого списка
  14. Обязательные аргументы в Python
  15. Создание новых списков в Python
  16. Преобразование числа в список цифр
  17. Генераторы в Python
  18. Закрытие файла в Python
  19. Библиотека Rich: форматирование текста
  20. Работа с SQLite в Python
  21. Отношения подклассов в Python
  22. Вложенные циклы в Python
  23. Генераторы списков
  24. Виртуальные среды в Python
  25. Копирование в Python
  26. Проверка типа данных
  27. Обход словаря в Python
  28. Удаление элемента из списка
  29. Срезы в Numpy
  30. Работа с CSV файлами
  31. Очистка списка от False, None, 0, «»
  32. Подписка на SelectelNews в Twitter
  33. Проверка надежности пароля на Python
  34. Передача словаря через **kwargs
  35. Глобальные переменные в Python
  36. Проверка на палиндром
  37. Оператор «not» в Python
  38. Python Метод del.
  39. Магические методы в Python
  40. Подсказки при вводе данных в Python
  41. Лямбда-функции в Python
  42. Печать списка с помощью метода join
  43. TON Smart Challenge #2: участие и подготовка
  44. Прокачанный трейсинг ошибок

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