OA0
OA0 是一个探索 AI 的社区
现在注册
已注册用户请  登录
OA0  ›  代码  ›  Instructor — 把大模型输出稳定映射为结构化数据的实用库

Instructor — 把大模型输出稳定映射为结构化数据的实用库

 
  breeze ·  2026-03-05 22:50:36 · 5 次点击  · 0 条评论  

Instructor:为 LLM 提供结构化输出

从任何 LLM 获取可靠的 JSON。基于 Pydantic 构建,提供验证、类型安全和 IDE 支持。

import instructor
from pydantic import BaseModel


# 定义你想要的结构
class User(BaseModel):
    name: str
    age: int


# 从自然语言中提取它
client = instructor.from_provider("openai/gpt-4o-mini")
user = client.chat.completions.create(
    response_model=User,
    messages=[{"role": "user", "content": "John is 25 years old"}],
)

print(user)  # User(name='John', age=25)

就这么简单。 无需 JSON 解析,无需错误处理,无需重试。只需定义一个模型,即可获得结构化数据。

PyPI
Downloads
GitHub Stars
Discord
Twitter

需要快速提取时使用 Instructor,需要智能体时选择 PydanticAI。 Instructor 让基于模式优先的流程保持简单且经济。如果你的应用需要更丰富的智能体运行、内置可观测性或可共享的追踪,请尝试 PydanticAI。PydanticAI 是 Pydantic 团队的官方智能体运行时,它添加了类型化工具、可重放的数据集、评估和生产仪表板,同时使用相同的 Pydantic 模型。深入阅读 PydanticAI 文档,了解它如何扩展 Instructor 风格的工作流。

为什么选择 Instructor?

从 LLM 获取结构化数据很困难。你需要:

  1. 编写复杂的 JSON 模式
  2. 处理验证错误
  3. 重试失败的提取
  4. 解析非结构化响应
  5. 应对不同供应商的 API

Instructor 通过一个简单的接口处理所有这些:

不使用 Instructor 使用 Instructor
response = openai.chat.completions.create(
    model="gpt-4",
    messages=[{"role": "user", "content": "..."}],
    tools=[
        {
            "type": "function",
            "function": {
                "name": "extract_user",
                "parameters": {
                    "type": "object",
                    "properties": {
                        "name": {"type": "string"},
                        "age": {"type": "integer"},
                    },
                },
            },
        }
    ],
)

# 解析响应
tool_call = response.choices[0].message.tool_calls[0]
user_data = json.loads(tool_call.function.arguments)

# 手动验证
if "name" not in user_data:
    # 处理错误...
    pass
client = instructor.from_provider("openai/gpt-4")

user = client.chat.completions.create(
    response_model=User,
    messages=[{"role": "user", "content": "..."}],
)

# 就这样!user 已经过验证并具有类型

几秒钟内完成安装

pip install instructor

或使用你的包管理器:

uv add instructor
poetry add instructor

兼容所有主流供应商

使用相同的代码与任何 LLM 供应商交互:

# OpenAI
client = instructor.from_provider("openai/gpt-4o")

# Anthropic
client = instructor.from_provider("anthropic/claude-3-5-sonnet")

# Google
client = instructor.from_provider("google/gemini-pro")

# Ollama (本地)
client = instructor.from_provider("ollama/llama3.2")

# 直接使用 API 密钥(无需环境变量)
client = instructor.from_provider("openai/gpt-4o", api_key="sk-...")
client = instructor.from_provider("anthropic/claude-3-5-sonnet", api_key="sk-ant-...")
client = instructor.from_provider("groq/llama-3.1-8b-instant", api_key="gsk_...")

# 全部使用相同的 API!
user = client.chat.completions.create(
    response_model=User,
    messages=[{"role": "user", "content": "..."}],
)

生产就绪特性

自动重试

验证失败时会自动使用错误信息重试:

from pydantic import BaseModel, field_validator


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

    @field_validator('age')
    def validate_age(cls, v):
        if v < 0:
            raise ValueError('年龄必须为正数')
        return v


# 当验证失败时,Instructor 会自动重试
user = client.chat.completions.create(
    response_model=User,
    messages=[{"role": "user", "content": "..."}],
    max_retries=3,
)

流式支持

在对象生成时流式传输部分结果:

from instructor import Partial

for partial_user in client.chat.completions.create(
    response_model=Partial[User],
    messages=[{"role": "user", "content": "..."}],
    stream=True,
):
    print(partial_user)
    # User(name=None, age=None)
    # User(name="John", age=None)
    # User(name="John", age=25)

嵌套对象

提取复杂的嵌套数据结构:

from typing import List


class Address(BaseModel):
    street: str
    city: str
    country: str


class User(BaseModel):
    name: str
    age: int
    addresses: List[Address]


# Instructor 自动处理嵌套对象
user = client.chat.completions.create(
    response_model=User,
    messages=[{"role": "user", "content": "..."}],
)

生产环境用户

受到超过 100,000 名开发者和构建 AI 应用的公司信赖:

  • 每月 300 万+ 次下载
  • 10,000+ GitHub 星标
  • 1000+ 社区贡献者

使用 Instructor 的公司包括 OpenAI、Google、Microsoft、AWS 的团队以及许多 YC 初创公司。

快速开始

基础提取

从任何文本中提取结构化数据:

from pydantic import BaseModel
import instructor

client = instructor.from_provider("openai/gpt-4o-mini")


class Product(BaseModel):
    name: str
    price: float
    in_stock: bool


product = client.chat.completions.create(
    response_model=Product,
    messages=[{"role": "user", "content": "iPhone 15 Pro, $999, available now"}],
)

print(product)
# Product(name='iPhone 15 Pro', price=999.0, in_stock=True)

多语言支持

Instructor 的简单 API 支持多种语言:

了解更多

为什么选择 Instructor 而非其他方案?

对比原生 JSON 模式:Instructor 提供自动验证、重试、流式传输和嵌套对象支持。无需手动编写模式。

对比 LangChain/LlamaIndex:Instructor 专注于一件事——结构化提取。它更轻量、更快、更易于调试。

对比自定义解决方案:经过数千名开发者的实战检验。处理了你可能尚未想到的边缘情况。

贡献

我们欢迎贡献!查看我们的 新手友好问题 开始吧。

许可证

MIT 许可证 - 详见 LICENSE


由 Instructor 社区构建。特别感谢 Jason Liu 和所有 贡献者

5 次点击  ∙  0 人收藏  
登录后收藏  
0 条回复
关于 ·  帮助 ·  PING ·  隐私政策 ·  服务条款   
OA0 - Omni AI 0 一个探索 AI 的社区
沪ICP备2024103595号-2
耗时 16 ms
Developed with Cursor