Курс 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"
- Курс Data Scientist в медицине
- Удаление элементов во время итерации
- Экспорт функций в Python
- Замена переменных в Python
- Генерация резюме в Gensim
- Метод join() для объединения элементов строки
- Работа с парами ключ-значение
- Numpy: объединение массивов
- Списковое включение в Python
- Импорт модулей в Python 3.12
- Округление банкира в Python
- Измерение времени выполнения в Python
- Отображение HTML кода в Python
- Поиск уникальных и повторяющихся элементов
- Управление памятью в Python
- Подписка на SelectelNews в Twitter
- Добавление элементов в список: append() vs extend()
- Транспонирование 2D-массива с помощью zip
- Возведение в квадрат с помощью itertools
- Очистка списка от False, None, 0, «»
- Руководство по Pymorphy2
- Метод get() в Python
- Настройка Cron
- Новшества Flask 2.0
- Работа с файлами в Python
- Поиск наиболее частого элемента
- Метод splitlines() для разделения строк
- Извлечение аудио из видео
- Ноутбуки AMD Ryzen ™ 4000: мощность и эффективность
- Python enumerate() функции
- Шаблоны и наследование в Flask
- Счетчик ссылок в Python
- Удаление символов новой строки в Python.
- Создание вложенных циклов for
- Структуры данных в Python
- Работа с YAML в Python: PyYAML.
- Функция с *args.
- Получение комбинаций в Python
- Функции с дополнением
- Списки: объединение, изменение
- Метод __irshift__ для Python
- Работа с deque в Python















