跳到主要内容

使用 Instructor 进行追踪(仅限 Python)

我们提供了与 Instructor 的便捷集成,Instructor 是一个流行的开源库,用于使用 LLM 生成结构化输出。

为了使用,您首先需要设置您的 LangSmith API 密钥。

export LANGSMITH_API_KEY=<your-api-key>

接下来,您需要安装 LangSmith SDK

pip install -U langsmith

使用 langsmith.wrappers.wrap_openai 包装您的 OpenAI 客户端

from openai import OpenAI
from langsmith import wrappers

client = wrappers.wrap_openai(OpenAI())

在此之后,您可以使用 instructor 补丁包装后的 OpenAI 客户端

import instructor

client = instructor.patch(client)

现在,您可以像平常一样使用 instructor,但现在一切都记录到 LangSmith 了!

from pydantic import BaseModel


class UserDetail(BaseModel):
name: str
age: int


user = client.chat.completions.create(
model="gpt-4o-mini",
response_model=UserDetail,
messages=[
{"role": "user", "content": "Extract Jason is 25 years old"},
]
)

通常,您在其他函数内部使用 instructor。您可以通过使用此包装的客户端并使用 @traceable 装饰这些函数来获得嵌套追踪。请参阅本指南,了解有关如何使用 @traceable 装饰器注释代码以进行追踪的更多信息。

# You can customize the run name with the `name` keyword argument
@traceable(name="Extract User Details")
def my_function(text: str) -> UserDetail:
return client.chat.completions.create(
model="gpt-4o-mini",
response_model=UserDetail,
messages=[
{"role": "user", "content": f"Extract {text}"},
]
)


my_function("Jason is 25 years old")

此页内容是否对您有帮助?


您可以留下详细的反馈 在 GitHub 上.