Django 异步生成器通过流式响应TypeError: ‘async_generator‘ object is not iterable

本文介绍了在Django中使用异步生成器和StreamingHttpResponse遇到的问题,通过创建stream装饰器并结合nest_asyncio库,展示了如何使异步函数与Django的流式响应功能协同工作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Django 异步生成器通过流式响应,本篇文章已解决

djagno项目的StreamingHttpResponse只支持响应迭代器,不支持异步生成器的方式去响应数据

默认情况会报错 TypeError: ‘async_generator‘ object is not iterable

Traceback (most recent call last):
  File "/usr/local/lib/python3.7/site-packages/django/core/handlers/base.py", line 231, in _get_response_async
    response = await wrapped_callback(request, *callback_args, **callback_kwargs)
=
  File "/usr/local/lib/python3.7/site-packages/django/http/response.py", line 386, in _set_streaming_content
    self._iterator = iter(value)
TypeError: 'async_generator' object is not iterable

解决方式:创建一个名为stream的装饰器,它可以与一个协程函数一起使用,使其与Django的StreamingHttpResponse兼容。
下面是一个例子:

1.url.py
# url
path('v1/index', index),  
2.view.py
import asyncio
import functools
from django.http import StreamingHttpResponse
def stream(coroutine_function):
    @functools.wraps(coroutine_function)
    def wrapper(*args, **kwargs):
        coroutine = coroutine_function(*args, **kwargs)
        try:
            while True:
                yield asyncio.run(coroutine.__anext__())
        except StopAsyncIteration:
            pass
    return wrapper
    
@stream
async def chunks():
    for char in 'Hello, world!':
        yield char
        await asyncio.sleep(1)
        
async def index(request):
    return StreamingHttpResponse(chunks())
3.安装 nest_asyncio
pip install nest_asyncio
4.在settings.py文件的顶部调用apply(), 添加以下代码
import nest_asyncio
nest_asyncio.apply()
5.接下来就是运行项目,调用接口,实现Django 异步生成器通过流式响应

至此,实现Django 异步生成器通过流式响应

如果需要对异步生成器的内容进行操作,可以以下实现

@stream
async def aaa():
    @stream
    async def chunks() -> iter:
            async for event in 返回异步生成器方法:
            	yield event
            	
    for i in chunks():
    	# 对chunk进行操作
        print(i)
        yield i

def index(request):
    return StreamingHttpResponse(aaa())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值