当前位置: 首页 > 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/274365.html

相关文章:

  • 本地门户网站系统网站推广哪个平台最好
  • 深圳网站建设价格是多少网络推广方法有哪几种
  • 企业网站源码库外链网站推荐几个
  • 做汽车网可参考网站百度账号查询
  • wordpress百度模板上海优化网站公司哪家好
  • 可以下载的网站模板网站关键词优化多少钱
  • 海外seo网站建设成都网站快速优化排名
  • 电子商务网站建设配色零基础seo入门教学
  • 解决设计网站问题免费友情链接交换平台
  • 杏坛网站建设竞价培训班
  • 长沙租房网seo科技网
  • 网站建设个人年终总结seo排名点击
  • 网站排名优化公司如何做好网上销售
  • 网站建设的资金风险seo运营专员
  • win10系统做mac系统下载网站游戏网站交换友情链接
  • asp做网站缺点百度云搜索引擎
  • 南通网站快照优化公司网站怎么才能被百度收录
  • 深圳好的网站建设公司排名网址收录平台
  • 如何做qq钓鱼网站百度seo怎么优化
  • 商城小程序开发发河南网站排名优化
  • 开个网站做英语培训查询网官网
  • 杭州seo排名收费站群优化公司
  • 云南建投第十建设有限公司网站做一个电商平台大概需要多少钱
  • 网络推广图片seo文章外包
  • 化妆品网站内容规划什么是网络营销平台
  • 免费网站建设公司代理广东省广州市佛山市
  • 深圳网站设计深圳网站建设深圳网络营销的公司哪家好
  • 广告公司网站建设方案苏州百度
  • 商务网站建设服务商强化防疫指导
  • 手机网站建设liedns竞价托管代运营公司