Курс 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. Декораторы в Python
  3. Библиотека wikipedia для Python
  4. Поиск индекса элемента в списке
  5. Операции с кортежами
  6. Логирование в Python
  7. Инверсия списка и строки
  8. Оптимизация параметров в Python
  9. Сортировка с помощью key
  10. Блок try-except-else
  11. Кортеж в Python: создание, доступ, изменение
  12. Метод join() с набором
  13. Работа с Event() в threading
  14. Создание словаря через dict comprehension
  15. Импорт и использование модулей в Python
  16. Отслеживание прогресса с tqdm
  17. Особенности запятых в Python
  18. Solidity для DeFi Ethereum
  19. Настройка Cron
  20. Различия символов в Python
  21. Загрузка постов Instagram
  22. Объединение списков в Python
  23. Работа с переменными в Python
  24. Сравнение def и lambda функций в Python
  25. Операторы += в Python
  26. Создание GUI на Tkinter
  27. Печать в одной строке
  28. Конкатенация строк с методом join()
  29. Избегайте двойного подчеркивания
  30. Функции-генераторы в Python
  31. Удаление эмодзи с помощью pandas
  32. Управление памятью в Python
  33. Оператор «моржа» (Walrus Operator)
  34. Упрощение работы с JSON-данными в Python
  35. Оператор (*) в Python
  36. Переопределение метода xor в Python
  37. Создание .exe файла с pyinstaller
  38. Выборка чисел
  39. Парсинг статей с Newspaper3k
  40. Классы данных в Python
  41. Реализация метода __abs__ в Python
  42. Обработка ошибок ввода данных
  43. Игра Виселица на Python
  44. Работа с комплексными числами
  45. Создание GUI с Tkinter: Entry
  46. Генераторы в Python
  47. Нахождение самого длинного слова в списке с помощью max

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