Курс 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"
- Фильтрация списка чисел
- Проверка элементов списка условием
- Аннотации типов в Python
- Сортировка с параметром key
- Декораторы классов
- Модуль os: работа с файлами и папками
- Списковое включение в Python
- Переворот списка в Python
- Оператор морж в Python 3.8
- Методы list в Python
- Группировка элементов Python
- Функции any() и all() в Python
- Удаление элемента по индексу
- Применение функций в Python
- Получение размера объекта с sys.getsizeof()
- Вычисление логарифмов в Python
- capitalize() — изменение регистра первого символа строки
- Поиск простых чисел
- Список импортированных модулей в Python
- Комментарии в Python
- Работа с JSON в Python
- Обязательные аргументы в Python
- Хранение данных
- Сортировка элементов с OrderedDict
- Декораторы с @wraps
- Функция print() — вывод информации
- Перемешивание списка с shuffle()
- Копирование объектов в Python
- Сравнение def и lambda функций в Python
- Метод count в Python: почему count(», ») возвращает 4?
- Проекты на Python
- Метод enumerate() в Python
- Удаление элементов из списка в Python
- Измерение времени выполнения кода
- Лямбда-функции для min/max
- Работа с географическими данными в Python
- Логические значения в Python
- Добавление элемента к кортежу
- Удаление первого элемента списка
- Методы HTTP запросов в Flask
- Объединение словарей в Python
- Символ подчеркивания в Python
- Настройка вывода в Numpy
- Оценка выражений генератора в Python
- Функции с дополнением
- Возврат нескольких значений
- Блок try-except-else
- Удаление специальных символов















