Skip to main content

Build LLM Agents in a Pythonic way

Project description

PyAgentic

Python Version License: MIT Code style: black Tests

A declarative, type-safe framework for building AI agents with OpenAI integration. PyAgentic lets you create sophisticated LLM agents using clean Python class syntax, with full support for tools, persistent state, agent linking, and agent inheritance.

Documentation

Read the Getting Started!

Complete documentation, tutorials, and examples can be found here

Features

  • Declarative Design - Define agents with simple class-based syntax and decorators
  • Powerful Tools - Easy @tool decoration with automatic OpenAI schema generation
  • Persistent State - Stateful agents with State fields that persist across conversations
  • Agent Linking - Compose complex workflows by linking agents together
  • Structured Responses - Type-safe Pydantic responses with full tool execution details
  • Dynamic Constraints - Use ref to create smart parameter validation
  • Inheritance & Extensions - Build agent hierarchies and mix in cross-cutting capabilities
  • Native Async Support - Built for scalable applications with async/await throughout
  • Type Safety - Complete typing support with validation and IDE autocompletion

Quick Start

Installation

pip install pyagentic-core

Simple Agent Example

from pyagentic import BaseAgent, tool, State, spec

class ResearchAgent(BaseAgent):
    __system_message__ = "I help with research tasks and maintain a collection of papers"

    # Persistent state that survives across conversations
    paper_count: State[int] = spec.State(default=0)
    current_topic: State[str] = spec.State(default="general", access="write")

    @tool("Search for academic papers")
    def search_papers(self, query: str, max_results: int = 5) -> str:
        # Your search logic here
        self.paper_count += max_results
        return f"Found {max_results} papers about '{query}'"

# Create and use the agent
agent = ResearchAgent(model="openai::gpt-4", api_key="your-key")
response = await agent("Help me research machine learning papers")

# Access structured response data
print(response.final_output)  # Natural language response
print(len(response.tool_responses))  # Number of tools called
print(agent.paper_count)  # Persistent state

Advanced Features

Agent Linking

Create multi-agent workflows where agents can call other agents as tools:

class DatabaseAgent(BaseAgent):
    __system_message__ = "I query databases"
    __description__ = "Retrieves data from SQL databases"

    @tool("Execute SQL query")
    def query(self, sql: str) -> str: ...

class WebAgent(BaseAgent):
    __system_message__ = "I search the web"
    __description__ = "Searches the internet"

    @tool("search")
    def search(self, terms: list[str]) -> str: ...

class ReportAgent(BaseAgent):
    __system_message__ = "I generate business reports"
    database: DatabaseAgent  # Linked agent appears as a tool
    searcher: WebAgent

    @tool("Create visualization")
    def create_chart(self, data: str) -> str: ...

# The report agent can automatically coordinate with the database agent
report_agent = ReportAgent(database=DatabaseAgent(...), searcher=WebAgent(...))
response = await report_agent("Generate a plot of the latest financial data")

Dynamic Parameter Constraints

Use ref with Pydantic computed fields to create intelligent parameter validation:

from pydantic import BaseModel, computed_field
from pyagentic import ref, spec

class DatasetState(BaseModel):
    available_datasets: list = []

    @computed_field
    @property
    def dataset_names(self) -> list[str]:
        return [ds['name'] for ds in self.available_datasets]

class DataAgent(BaseAgent):
    __system_message__ = "I manage datasets"

    datasets: State[DatasetState] = spec.State(default_factory=DatasetState)

    @tool("Analyze specific dataset")
    def analyze(
        self,
        dataset: str = spec.Param(
            description="Dataset to analyze",
            values=ref.datasets.dataset_names  # LLM can only pick from available datasets
    )) -> str: ...

Contributing

Contribution is welcome! Whether it's bug fixes, new features, documentation improvements, or examples, help is appreciated.

Development Setup

  1. Clone the repository

    git clone https://github.com/your-username/pyagentic.git
    cd pyagentic
    
  2. Install dependencies with uv

    # Install uv if you haven't already
    pip install uv
    
    # Install all dependencies including dev tools
    uv sync --group dev
    

Code Quality

Several tools are used to maintain code quality:

Formatting with Black

# Format all Python files
uv run black -l99 pyagentic tests

# Check formatting without making changes
uv run black -l99 --check pyagentic tests

Linting with Flake8

# Run linting checks
uv run flake8 --max-line-length=99 pyagentic tests 

Testing

# Run all tests
uv run pytest tests

# Run tests with coverage
uv run coverage run -m pytest tests

Documentation

Documentation is built with MkDocs and deployed automatically:

Local Development

# Install docs dependencies
uv sync --group docs

# Serve docs locally (auto-reloads on changes)
uv run task serve-docs

# Build docs to ./site/
uv run task build-docs

Docs are automatically deployed on pushes to main via GitHub Actions.

Submitting Changes

  1. Create a feature branch

    git checkout -b feature/your-feature-name
    
  2. Make your changes following the code style guidelines

  3. Run the full test suite

    uv run black pyagentic tests
    uv run flake8 pyagentic tests --max-line-length=99
    uv run pytest
    
  4. Commit with conventional commit messages

    git commit -m "feat: add new agent linking feature"
    git commit -m "fix: resolve context persistence issue"
    git commit -m "docs: improve getting started guide"
    
  5. Push and create a Pull Request

    git push origin feature/your-feature-name
    

Conventional Commits

Conventional commits are used for automatic versioning:

  • feat: - New features (minor version bump)
  • fix: - Bug fixes (patch version bump)
  • docs: - Documentation changes
  • test: - Test additions or improvements
  • refactor: - Code refactoring
  • style: - Code style changes (formatting, etc.)

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

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

pyagentic_core-2.0.1a1.tar.gz (51.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyagentic_core-2.0.1a1-py3-none-any.whl (64.5 kB view details)

Uploaded Python 3

File details

Details for the file pyagentic_core-2.0.1a1.tar.gz.

File metadata

  • Download URL: pyagentic_core-2.0.1a1.tar.gz
  • Upload date:
  • Size: 51.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for pyagentic_core-2.0.1a1.tar.gz
Algorithm Hash digest
SHA256 cb6a3f05818102745e1af1b59a209d594f75d4b7569ae8b29a994ad4950f89e9
MD5 5ebead0d74afdaa2dea0404a1588f3a1
BLAKE2b-256 0ed71525baba99c27741a3949c1c0fe7d1899394b43a57fc030d3f446bd0e52f

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyagentic_core-2.0.1a1.tar.gz:

Publisher: release.yml on rmikulec/pyAgentic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyagentic_core-2.0.1a1-py3-none-any.whl.

File metadata

File hashes

Hashes for pyagentic_core-2.0.1a1-py3-none-any.whl
Algorithm Hash digest
SHA256 c7bc6dad19884014fcd5f0409ef9c91016d19c8c3784771b5f0d891341b1139d
MD5 de0f1442e23b3bc4bcbf6bf6c67f3086
BLAKE2b-256 6c2c815359a74e4e0cc7024249e7d367383c23f7ffe6e47e3097734d9b95f63e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyagentic_core-2.0.1a1-py3-none-any.whl:

Publisher: release.yml on rmikulec/pyAgentic

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page