Pydantic shim for config stuff
Project description
Schemez
OpenAI Function Schema Generator
Convert Python functions to OpenAI-compatible function schemas automatically.
Installation
pip install schemez
Basic Usage
from schemez import create_schema
from typing import Literal
def get_weather(
location: str,
unit: Literal["C", "F"] = "C",
detailed: bool = False,
) -> dict[str, str | float]:
"""Get the weather for a location.
Args:
location: City or address to get weather for
unit: Temperature unit (Celsius or Fahrenheit)
detailed: Include extended forecast
"""
return {"temp": 22.5, "conditions": "sunny"}
# Create schema
schema = create_schema(get_weather)
# The schema.model_dump_openai() returns a TypedDict with the complete OpenAI tool definition:
# OpenAIFunctionTool = TypedDict({
# "type": Literal["function"],
# "function": OpenAIFunctionDefinition
# })
# Use with OpenAI
from openai import OpenAI
client = OpenAI()
response = client.chat.completions.create(
model="gpt-4",
messages=[{"role": "user", "content": "What's the weather in London?"}],
tools=[schema.model_dump_openai()], # Schema includes the type: "function" wrapper
tool_choice="auto"
)
Note: This library supports the OpenAI API v1 format (openai>=1.0.0). For older versions of the OpenAI package that use the legacy functions API, you'll need to unwrap the function definition using
schema.model_dump_openai()["function"].
## Supported Types
### Basic Types
```python
def func(
text: str, # -> "type": "string"
number: int, # -> "type": "integer"
amount: float, # -> "type": "number"
enabled: bool, # -> "type": "boolean"
anything: Any, # -> "type": "string"
) -> None: ...
Container Types
def func(
items: list[str], # -> "type": "array", "items": {"type": "string"}
numbers: set[int], # -> same as list
mapping: dict[str, Any], # -> "type": "object", "additionalProperties": true
nested: list[dict[str, int]], # -> nested array/object types
sequence: Sequence[str], # -> "type": "array"
collection: Collection[int], # -> "type": "array"
) -> None: ...
Enums and Literals
class Color(Enum):
RED = "red"
BLUE = "blue"
def func(
color: Color, # -> "type": "string", "enum": ["red", "blue"]
mode: Literal["fast", "slow"], # -> "type": "string", "enum": ["fast", "slow"]
) -> None: ...
Optional and Union Types
def func(
opt1: str | None, # -> "type": "string"
opt2: int | None, # -> "type": "integer"
union: str | int, # -> "type": "string" (first type)
) -> None: ...
Custom Types
@dataclass
class User:
name: str
age: int
def func(
user: User, # -> "type": "object"
data: JsonDict, # -> "type": "object"
) -> None: ...
Type Aliases
JsonValue = dict[str, Any] | list[Any] | str | int | float | bool | None
JsonDict = dict[str, JsonValue]
def func(
data: JsonDict, # -> "type": "object"
values: list[JsonValue], # -> "type": "array"
) -> None: ...
Recursive Types
def func(
tree: dict[str, "dict[str, Any] | str"], # -> "type": "object"
nested: dict[str, list["dict[str, Any]"]], # -> "type": "object"
) -> None: ...
Generated Schema Example
{
"type": "function",
"function": {
"name": "get_weather",
"description": "Get the weather for a location.",
"parameters": {
"type": "object",
"properties": {
"location": {
"type": "string",
"description": "City or address to get weather for"
},
"unit": {
"type": "string",
"enum": ["C", "F"],
"description": "Temperature unit (Celsius or Fahrenheit)",
"default": "C"
},
"detailed": {
"type": "boolean",
"description": "Include extended forecast",
"default": false
}
},
"required": ["location"]
}
}
}
Schema Generators
Module Schemas
You can generate schemas for all public functions in a module using create_schemas_from_module:
from schemez import create_schemas_from_module
import math
# Generate schemas for all public functions
schemas = create_schemas_from_module(math)
# Generate schemas for specific functions only
schemas = create_schemas_from_module(math, include_functions=['sin', 'cos'])
# Import module by string name
schemas = create_schemas_from_module('math')
Class Schemas
Generate schemas for all public methods in a class using create_schemas_from_class:
from schemez import create_schemas_from_class
class Calculator:
def add(self, x: int, y: int) -> int:
"""Add two numbers.
Args:
x: First number
y: Second number
Returns:
Sum of x and y
"""
return x + y
@classmethod
def multiply(cls, x: int, y: int) -> int:
"""Multiply two numbers.
Args:
x: First number
y: Second number
Returns:
Product of x and y
"""
return x * y
@staticmethod
def divide(x: float, y: float) -> float:
"""Divide two numbers.
Args:
x: Numerator
y: Denominator
Returns:
Result of x divided by y
"""
return x / y
# Generate schemas for all public methods
schemas = create_schemas_from_class(Calculator)
# Access individual method schemas
add_schema = schemas['Calculator.add']
multiply_schema = schemas['Calculator.multiply']
divide_schema = schemas['Calculator.divide']
The schema generators support:
- Regular functions
- Regular instance methods (bound and unbound)
- Class methods
- Static methods
- Decorated functions / methods
- Async functions / methods
- Property methods
- Basically all stdlib typing features as well as many stdlib types
- Method docstrings for descriptions
- Default values
- Return type hints
Diferences to pydantic schema generation
While Pydantics schema generation preserves detailed type information, schema.model_dump_openai()
simplifies types to match OpenAI's function calling format. Most special types
(datetime, UUID, Path, etc.) are handled similarly by both (we only strip unused information), but we handle enums
differently: Instead of preserving enum class information, we extract just the values
as a string enum. Union types and Optionals are also handled differently - we typically
pick the first type to keep the schema simple and practical for AI interaction.
This ensures compatibility with OpenAI's function calling API while maintaining enough
type information for the AI to understand the function signature.
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
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 schemez-1.2.4.tar.gz.
File metadata
- Download URL: schemez-1.2.4.tar.gz
- Upload date:
- Size: 35.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
98948183c1e41266f35dd9c3397a76755ee63f5a9a83a3dcc6f3dffcf337963e
|
|
| MD5 |
00917728b63bf5e79415709f50a91462
|
|
| BLAKE2b-256 |
3420d8c13e3ed4ba884d0a7067ca0fc31fc83d3d4a151228c731bed087b4a700
|
Provenance
The following attestation bundles were made for schemez-1.2.4.tar.gz:
Publisher:
build.yml on phil65/schemez
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
schemez-1.2.4.tar.gz -
Subject digest:
98948183c1e41266f35dd9c3397a76755ee63f5a9a83a3dcc6f3dffcf337963e - Sigstore transparency entry: 621364908
- Sigstore integration time:
-
Permalink:
phil65/schemez@3377c6a377cf59d22721b7f84ba36c963c9cc3c1 -
Branch / Tag:
refs/tags/v1.2.4 - Owner: https://github.com/phil65
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@3377c6a377cf59d22721b7f84ba36c963c9cc3c1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file schemez-1.2.4-py3-none-any.whl.
File metadata
- Download URL: schemez-1.2.4-py3-none-any.whl
- Upload date:
- Size: 42.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49100d7f8e27d0d648d1108be4b4ff962111ce3726aa664e6e314521775ed2a4
|
|
| MD5 |
27931737a19cc30feac90bc46cdbc37a
|
|
| BLAKE2b-256 |
23aa20afbaca4bc98b45ded5f0b921f16510b2214e44f9ea1565e18c126485ac
|
Provenance
The following attestation bundles were made for schemez-1.2.4-py3-none-any.whl:
Publisher:
build.yml on phil65/schemez
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
schemez-1.2.4-py3-none-any.whl -
Subject digest:
49100d7f8e27d0d648d1108be4b4ff962111ce3726aa664e6e314521775ed2a4 - Sigstore transparency entry: 621364910
- Sigstore integration time:
-
Permalink:
phil65/schemez@3377c6a377cf59d22721b7f84ba36c963c9cc3c1 -
Branch / Tag:
refs/tags/v1.2.4 - Owner: https://github.com/phil65
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build.yml@3377c6a377cf59d22721b7f84ba36c963c9cc3c1 -
Trigger Event:
push
-
Statement type: