Курс 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. Синхронизация потоков с time.sleep()
  5. Отделение звука от видео
  6. Работа с контекстными переменными
  7. Модуль sys: основы
  8. Оператор умножения для вектора
  9. Работа с множествами в Python
  10. Область видимости переменных
  11. Поиск с библиотекой Google
  12. Нахождение пересечения множеств
  13. Экранирование символов в Python
  14. Хранение данных
  15. Создание класса в Python
  16. PATCH-запрос с библиотекой requests
  17. Сериализация объектов в Python
  18. Роль запятой в Python
  19. Официальный канал Python в Telegram
  20. Retrying в Python: повторные вызовы
  21. Операторы увеличения и уменьшения в Python
  22. Расчет времени выполнения программы
  23. Удаление элемента из списка в Python
  24. UserList в Python: Описание и примеры использования
  25. Принципы программирования
  26. Хэш-функции и метод цепочек
  27. CSV строка разделение в Python
  28. Метод ifloordiv для пользовательских классов
  29. Работа с deque из collections
  30. Назначение максимального и минимального значения переменной в Python.
  31. Сортировка в Python
  32. Модуль pprint: улучшение вывода данных
  33. Нан-рефлексивность в Python
  34. Функциональное программирование в Python
  35. Создание виртуальной среды
  36. Генерация QR-кодов с библиотекой qrcode
  37. Расчет времени выполнения кода
  38. Обработка исключений в Python
  39. Установка User-Agent в Python
  40. Фильтрация элементов с помощью islice
  41. Antigravity модуль
  42. Структура данных словарь в Python
  43. Сортировка в Python
  44. Преобразование символов с помощью map
  45. Работа с датой и временем в Python

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