Курс 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. Создание циклической ссылки
  3. Поиск шаблона в строке
  4. Генерация резюме в Gensim
  5. Встраивание HTML в Jupyter Notebook
  6. Метод index() в Python
  7. Создание списка через итерацию
  8. Оператор умножения для вектора
  9. Оценка выражений генератора в Python
  10. Python Тесты и Гайды
  11. Сортировка HTML-элементов
  12. Генераторы в Python
  13. Генераторные функции в Python
  14. Метод __complex__ в Python
  15. Инверсия списка и строки
  16. Декораторы в Python
  17. Итераторы с потерямиZIP
  18. Курсы Яндекс Практикум
  19. Методы сравнения множеств
  20. Дефолтные параметры в Python
  21. Функция zip() в Python
  22. Преобразование генераторов в циклы
  23. Лимиты на ресурсы Python
  24. Руководство по использованию Colorama
  25. Метод __irshift__ для побитового сдвига вправо
  26. Работа со строками в Python.
  27. Уникальность ключей в словаре
  28. Утечки переменных цикла в Python 3.x
  29. Непрерывная проверка в Python
  30. Проверка дублей в списке.
  31. Объединение словарей в Python
  32. Метод pos в Python
  33. Оператор += для объединения строк
  34. Определение имен функций
  35. Сумма элементов списка
  36. Работа с путями в Python
  37. Хешируемые ключи в Python
  38. Циклы в Python
  39. Игра Виселица на Python
  40. Методы обработки строк в Python
  41. Загрузка постов Instagram
  42. Выбор редактора кода.
  43. Работа со случайными элементами
  44. Вычисление фазы комплексного числа
  45. Списковые включения в Python
  46. Метод join() для объединения строк

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