Курс 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. Проверка элементов списка условием
  3. Аннотации типов в Python
  4. Сортировка с параметром key
  5. Декораторы классов
  6. Модуль os: работа с файлами и папками
  7. Списковое включение в Python
  8. Переворот списка в Python
  9. Оператор морж в Python 3.8
  10. Методы list в Python
  11. Группировка элементов Python
  12. Функции any() и all() в Python
  13. Удаление элемента по индексу
  14. Применение функций в Python
  15. Получение размера объекта с sys.getsizeof()
  16. Вычисление логарифмов в Python
  17. capitalize() — изменение регистра первого символа строки
  18. Поиск простых чисел
  19. Список импортированных модулей в Python
  20. Комментарии в Python
  21. Работа с JSON в Python
  22. Обязательные аргументы в Python
  23. Хранение данных
  24. Сортировка элементов с OrderedDict
  25. Декораторы с @wraps
  26. Функция print() — вывод информации
  27. Перемешивание списка с shuffle()
  28. Копирование объектов в Python
  29. Сравнение def и lambda функций в Python
  30. Метод count в Python: почему count(», ») возвращает 4?
  31. Проекты на Python
  32. Метод enumerate() в Python
  33. Удаление элементов из списка в Python
  34. Измерение времени выполнения кода
  35. Лямбда-функции для min/max
  36. Работа с географическими данными в Python
  37. Логические значения в Python
  38. Добавление элемента к кортежу
  39. Удаление первого элемента списка
  40. Методы HTTP запросов в Flask
  41. Объединение словарей в Python
  42. Символ подчеркивания в Python
  43. Настройка вывода в Numpy
  44. Оценка выражений генератора в Python
  45. Функции с дополнением
  46. Возврат нескольких значений
  47. Блок try-except-else
  48. Удаление специальных символов

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