当前位置: 首页 > wzjs >正文

临桂住房和城乡建设局网站网站建设的团队分工

临桂住房和城乡建设局网站,网站建设的团队分工,长春好的做网站公司,网站设计基本流程OpenAI 流式的代码: 首选一般请使用os.getenv 去读环境变量的内容 注意使用pip install python-dotenv 的安装方法 load_dotenv 是这个库提供的一个函数,用于读取 .env 文件并将其中定义的键值对设置为系统的环境变量。 默认情况下,load_…

OpenAI 流式的代码:

首选一般请使用os.getenv 去读环境变量的内容

注意使用pip install python-dotenv 的安装方法

load_dotenv 是这个库提供的一个函数,用于读取 .env 文件并将其中定义的键值对设置为系统的环境变量。

默认情况下,load_dotenv() 会自动查找当前目录下的 .env 文件。如果文件不在默认路径,可以通过参数指定,例如 load_dotenv(‘/path/to/.env’)。

为什么代码里用 dotenv 而不是 python_dotenv?

在 Python 中,导入模块时使用的是库的模块名,而不是 PyPI 上的包名。python-dotenv 这个包安装后,提供了一个名为 dotenv 的模块供导入。这是由库开发者决定的命名约定。例如:

  • PyPI 包名:python-dotenv
  • 导入时的模块名:dotenv

流式代码 类 (一键运行)

from openai import  AsyncOpenAI
from dotenv import load_dotenv
import osload_dotenv()class AsyncOpenAIOut:def __init__(self):self.api_key = os.getenv("OPENAI_API_KEY")self.base_url = os.getenv("OPENAI_BASE_URL")self.oai_client = AsyncOpenAI(api_key=self.api_key, base_url=self.base_url)self.model = os.getenv("OPENAI_MODEL")async def gpt_stream(self, user_message: str,model: str = os.getenv("OPENAI_MODEL"),history: list[dict] = [],system_prompt: str = "") :messages = []if history:messages.extend(history)if system_prompt:messages.extend([{"role": "system", "content": system_prompt}])messages.append({"role": "user", "content": user_message})response = await self.oai_client.chat.completions.create(model=model,messages=messages,stream=True)async for chunk in response:if chunk.choices[0].delta.content:yield chunk.choices[0].delta.contentasync_openai_out = AsyncOpenAIOut()if __name__ == "__main__":async def test_gpt_stream():async for chunk in async_openai_out.gpt_stream(user_message="写300字作文",system_prompt="You are a helpful assistant."):print(chunk)import asyncioasyncio.run(test_gpt_stream())

这里面有几点需要注意:

简短回答:print(chunk) 是 同步操作会在当前事件循环中执行完毕后才继续但它不是 I/O 密集型操作,所以不会造成实际的“阻塞”问题,特别是在异步函数中逐步输出内容的场景下,它是可接受的。

想确保异步非阻塞输出:

        async for chunk in async_openai_out.gpt_stream(user_message="写300字作文",system_prompt="You are a helpful assistant."):# print(chunk)await asyncio.to_thread(print, chunk)  # 在后台线程执行 print

异步生成器(Async Generator) 的用法,结合了 Python 的异步编程(async for)和生成器(yield)机制。

在异步迭代 response 中的每个 chunk,如果它有内容,就通过 yield 一块一块地“流式返回”。

async for chunk in response:if chunk.choices[0].delta.content:yield chunk.choices[0].delta.content

对比for : 普通for是同步迭代

async for是异步迭代,比如网络流、WebSocket、OpenAI 的 Stream 响应等。

yield 是生成器的关键,它不是“返回”值,而是“产出”值(可以被迭代一次)。

http://www.dtcms.com/wzjs/815096.html

相关文章:

  • 微信网站开发设计WordPress如何添加表情
  • 网站设计原则的历史wordpress2.4
  • 网站做sem能够提高收录量吗google seo 优化教程
  • 天安保险公司官网广州网站优化哪家快
  • 如何建造企业网站咸宁网站建设公司
  • 现在搜什么关键词能搜到网站做阿里巴巴英文网站
  • 外贸企业网站制作seo搜索推广
  • 易思企业网站管理系统做羞羞的事情的网站
  • 网站开发设计参考文献宁浩wordpress
  • 室内设计者联盟网站浙江省建筑培训网
  • 毕业设计做网站答辩网站建设不好
  • 医疗网站建设好么石嘴山网站建设
  • 怎样做网站 app教程网站上的链接怎么做的
  • 中国住房城乡建设厅网站wordpress api 路径
  • 大连网站建设特色发布培训的免费网站模板下载
  • 深圳二次源网站建设四川省建设科技协会网站
  • 湖北网站建设哪家好中国建设工程网站投标
  • 大兴网站建设it外包人员最后什么下场
  • 厦门创意互动网站建设php企业cms
  • 上海网站建设 百家号小店面设计装修网
  • 天津网站建设 熊掌号可信网站认证购买
  • 炫酷网站设计化妆品网站建设报告
  • wordpress 手机网站支付宝绍兴网站公司网站制作
  • 成都网站设计说明书漳州 网站建设多少钱
  • 全国招商代理平台重庆百度seo整站优化
  • 建网站要钱吗网站可以做充值吗
  • 网站设计咨询电话建湖做网站的公司
  • 一个成功的网站要具备哪些网站要多少钱
  • 常用网站png做网站哪里需要用钱
  • 自己动手建立网站3浙江建设职业技术学院招生网站