LLMの出力をPydanticモデルで型安全に扱うためのPythonライブラリ
Project description
dariko
LLMの出力をPydanticモデルで型安全に扱うためのPythonライブラリ。
特徴
- LLMの出力をPydanticモデルで型安全に扱える
- 型アノテーションから自動的に出力モデルを推論
- バッチ処理に対応
- シンプルなAPI
- 環境変数から自動的にAPIキーを読み込み
インストール
pip install dariko
使用方法
基本的な使い方
from pydantic import BaseModel
from dariko import ask
# 出力モデルの定義
class Person(BaseModel):
name: str
age: int
dummy: bool
# 型アノテーションから自動的にモデルを推論
result: Person = ask("以下の形式のJSONを返してください:\n" + '{"name": "山田太郎", "age": 25, "dummy": false}')
print(result.name) # "山田太郎"
print(result.age) # 25
print(result.dummy) # False
明示的にモデルを指定
result = ask("test", output_model=Person)
バッチ処理
from dariko import ask_batch
prompts = [
"以下の形式のJSONを返してください:\n" + '{"name": "山田太郎", "age": 25, "dummy": false}',
"以下の形式のJSONを返してください:\n" + '{"name": "佐藤花子", "age": 30, "dummy": true}',
]
results = ask_batch(prompts, output_model=Person)
# 結果の表示
for i, result in enumerate(results, 1):
print(f"\n人物 {i}:")
print(f"名前: {result.name}")
print(f"年齢: {result.age}")
print(f"ダミー: {result.dummy}")
型推論の実践例
関数の戻り値型アノテーションによる推論
def get_person() -> Person:
return ask('以下の形式のJSONを返してください:\n{"name": "山田太郎", "age": 25, "dummy": false}')
person = get_person()
print(person.name) # "山田太郎"
変数アノテーションによる推論
result: Person = ask('以下の形式のJSONを返してください:\n{"name": "佐藤花子", "age": 30, "dummy": true}')
print(result.name) # "佐藤花子"
バッチ処理でも型推論が効く
from typing import List
def get_people() -> List[Person]:
prompts = [
'以下の形式のJSONを返してください:\n{"name": "山田太郎", "age": 25, "dummy": false}',
'以下の形式のJSONを返してください:\n{"name": "佐藤花子", "age": 30, "dummy": true}',
]
return ask_batch(prompts)
people = get_people()
for p in people:
print(p.name)
注意点
- 型アノテーションが取得できない場合は
output_modelを明示的に指定してください。 - 型推論は「関数の戻り値型」→「変数アノテーション」→「AST解析」の順で行われます。
- 型アノテーションはPydanticのBaseModelサブクラスである必要があります。
型推論の仕組み
Darikoは以下の優先順位で型を推論します:
- 呼び出し元関数のreturn型ヒント
- 現フレームのローカル変数アノテーション(1個だけの場合)
- AST解析による推定
詳細な実装については、examples/logic.mdを参照してください。
環境変数
以下の環境変数を設定することで、Darikoの動作を制御できます:
DARIKO_API_KEY: APIキー(必須)DARIKO_MODEL: 使用するモデル名(デフォルト: "gpt-4")
開発
セットアップ
git clone https://github.com/yourusername/dariko.git
cd dariko
pip install -e .
テスト
pytest tests/
リリースプロセス
- 変更をコミットしてプルリクエストを作成:
./scripts/release.sh
-
スクリプトの実行手順:
- コミットタイプを選択(新機能/バグ修正/破壊的変更)
- 変更内容を入力
- 破壊的変更の場合は詳細を入力
-
バージョン管理の仕組み:
- コミットメッセージに基づいて自動的にバージョンが更新されます
feat:→ マイナーバージョンアップ(0.1.0 → 0.2.0)fix:→ パッチバージョンアップ(0.1.0 → 0.1.1)BREAKING CHANGE:→ メジャーバージョンアップ(0.1.0 → 1.0.0)
-
リリースの流れ:
- プルリクエストが作成されます
- レビュー後にマージ
- マージされると自動的に:
- バージョンが更新
- GitHubリリースが作成
- PyPIにパッケージがアップロード
-
注意点:
- コミットメッセージはAngularのコミットメッセージ規約に従ってください
- 複数のコミットがある場合、最も大きな変更に基づいてバージョンが更新されます
- GitHub CLI(
gh)のインストールと認証が必要です
ライセンス
MIT License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
dariko-1.0.3.tar.gz
(15.0 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dariko-1.0.3.tar.gz.
File metadata
- Download URL: dariko-1.0.3.tar.gz
- Upload date:
- Size: 15.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4668a8201550a230f37748b56e79ba839839ef5f954eb8477d4b0a5eff2102c9
|
|
| MD5 |
e9e4a3df6f76c9850f2a4ba4aa5ac7a4
|
|
| BLAKE2b-256 |
b8a975147548df6bd228485daec03499b1ef114b49135bfb05a096cb155c01ae
|
File details
Details for the file dariko-1.0.3-py3-none-any.whl.
File metadata
- Download URL: dariko-1.0.3-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a04ab24686f32da0ce3974d07abfa80107e62794cce8afc34e3b64c087acd79e
|
|
| MD5 |
3d9a2f7e0828390fa9ba3849a195d051
|
|
| BLAKE2b-256 |
7b95e0b65de2dde1ffb33869b965f4a92a324621d0609a6dd3f87500c1152ff6
|