コンテンツにスキップ

OpenAI Agents SDK TypeScript

クイックスタート

ほんの数分ではじめてのエージェントをつくることができます。

はじめる
import { Agent, run } from '@openai/agents';
const agent = new Agent({
name: 'Assistant',
instructions: 'You are a helpful assistant.',
});
const result = await run(
agent,
'Write a haiku about recursion in programming.',
);
console.log(result.finalOutput);

TypeScript 向け OpenAI Agents SDK は、抽象化を最小限に抑えた軽量で使いやすいパッケージで、エージェント型 AI アプリを構築できます。これは以前のエージェント向け実験的ライブラリである Swarm を本番運用向けに強化したもので、Python 版も利用可能です。Agents SDK にはごく少数の基本コンポーネントがあります。

  • Agents: instructions と tools を備えた LLM
  • Handoffs: 特定のタスクを他のエージェントに委譲する仕組み
  • Guardrails: エージェントへの入力を検証できる仕組み

これらの基本コンポーネントは TypeScript と組み合わせることで、ツールとエージェント間の複雑な関係を表現し、学習コストを抑えながら実運用アプリケーションを構築できます。さらに、SDK には組み込みの トレーシング があり、エージェントのフローを可視化・デバッグし、評価やアプリ向けのモデルのファインチューニングまで行えます。

SDK の設計原則は次の 2 点です。

  1. 使う価値のある機能は十分に備えつつ、学びやすいよう基本コンポーネントは少数にすること
  2. そのままでもよく動作し、必要に応じて挙動を細かくカスタマイズできること

主な機能は次のとおりです。

  • エージェントループ: ツールの呼び出し、結果の LLM への送信、LLM が完了するまでのループを内蔵
  • TypeScript ファースト: 新しい抽象を学ぶのではなく、言語の組み込み機能でエージェントをオーケストレーションし連結
  • Handoffs: 複数エージェント間での調整と委譲を可能にする強力な機能
  • Guardrails: エージェントと並行して入力の検証やチェックを実行し、失敗時は早期に中断
  • 関数ツール: 任意の TypeScript 関数をツール化し、自動スキーマ生成と Zod ベースの検証を提供
  • トレーシング: フローの可視化、デバッグ、監視に加え、OpenAI の評価、ファインチューニング、蒸留のツール群を活用可能
  • リアルタイムエージェント: 自動割り込み検出、コンテキスト管理、ガードレールなどを備えた強力な音声エージェントを構築
Terminal window
npm install @openai/agents zod@3
Hello World
import { Agent, run } from '@openai/agents';
const agent = new Agent({
name: 'Assistant',
instructions: 'You are a helpful assistant',
});
const result = await run(
agent,
'Write a haiku about recursion in programming.',
);
console.log(result.finalOutput);
// Code within the code,
// Functions calling themselves,
// Infinite loop's dance.

(実行する場合は、OPENAI_API_KEY 環境変数を設定してください)

Terminal window
export OPENAI_API_KEY=sk-...