Skip to main content

Utilities for orchestrating OpenAI chat, tool calling, search, audio, and images from one helper package.

Project description

Code style: black License: MIT python Static Badge

Easier OpenAI

Easier OpenAI wraps the official OpenAI Python SDK so you can drive modern assistants, manage tool selection, search files, and work with speech from one helper package -- all with minimal boilerplate.

Features

  • High level Assistant wrapper with conversation memory, tool toggles, and streaming helpers.
  • Temporary vector store ingestion to ground answers in local notes or documents.
  • Text to speech and speech to text bridges designed for quick experiments or internal tooling.
  • Built-in helper for defining and executing OpenAI function tools without leaving Python.
  • Lazy module loading so import easier_openai stays fast even as optional helpers expand.
  • Type hints and comprehensive inline docstrings across the project for easier discovery.

Installation

pip install easier-openai

Optional extras:

pip install "easier-openai[function_tools]"   # decorator helpers
pip install "easier-openai[speech_models]"    # whisper speech recognition models

Set the OPENAI_API_KEY environment variable or pass api_key directly when instantiating Assistant.

Quick Start

from easier_openai import Assistant

assistant = Assistant(model="gpt-4o-mini", system_prompt="You are concise.")
response_text = assistant.chat("Summarize Rayleigh scattering in one sentence.")
print(response_text)

sped-up video. actual time ~1 min:

https://github.com/user-attachments/assets/8d2340ac-e4ac-4163-8ec0-a7a226b6d1b6

Tool Calling Made Simple

Use Assistant.openai_function to convert regular functions into structured tool definitions and hand them to chat:

from easier_openai import Assistant

assistant = Assistant()

@assistant.openai_function
def look_up_fact(topic: str) -> dict:
    """Return a knowledge base lookup result for the given topic."""
    return {"topic": topic}

assistant.chat(
    "Tell me about the ozone layer using the fact tool.",
    custom_tools=[look_up_fact],
)

Stream Responses with Tools

stream = assistant.chat(
    "Summarise launch blockers for the robotics demo",
    custom_tools=[look_up_fact],
    text_stream=True,
)
for delta in stream:
    if delta == "done":
        break
    print(delta, end="", flush=True)

Ground Responses With Your Files

notes = ["notes/overview.md", "notes/data-sheet.pdf"]
reply = assistant.chat(
    "Highlight key risks from the attached docs",
    file_search=notes,
    tools_required="auto",
)
print(reply)

Speech I/O

Generate audio output directly from assistant responses:

assistant.full_text_to_speech(
    "Ship a status update that sounds upbeat",
    model="gpt-4o-mini-tts",
    voice="alloy",
    play=True,
)

full_text_to_speech accepts the same keyword arguments as chat, so you can pass custom_tools, file_search, or web_search before the reply is spoken.

Or capture short dictated prompts without leaving the terminal:

transcript = assistant.speech_to_text(mode="vad", model="base.en")
print(transcript)

Image Utilities

Openai_Images extends the assistant with helpers that accept URLs, file paths, or base64 payloads and normalise them for the Images API:

from easier_openai import Openai_Images

image_client = Openai_Images("samples/promenade.jpg")
# Generated metadata is stored on image_client.image for re-use in calls.

Configuration Reference

  • model: Default model used for chat, tool calls, and reasoning workflows. Choosing a realtime model (for example gpt-4o-realtime-preview) automatically routes Assistant.chat through the Realtime API for text-only prompts; install openai[realtime] to satisfy its websocket dependency. Tool execution and the stream flag are ignored while a realtime model is active.
  • system_prompt: Injected once per conversation to shape assistant behaviour.
  • reasoning_effort and summary_length: Fine tune reasoning models via the official API semantics.
  • temperature: Pass through value mapped to OpenAI responses for deterministic vs creative answers.
  • function_call_list: Pre-register decorated tool callables that should accompany every chat request.
  • default_conversation: Set to False if you prefer to supply conversation IDs manually.
  • mass_update(**kwargs): Bulk update configuration attributes using keyword arguments validated by type hints.
assistant.mass_update(model="gpt-4o-mini", temperature=0.2)
assistant.mass_update(reasoning_effort="high", summary_length="concise")

Developer Notes

  • Every public function and class ships with contextual docstrings to make the codebase self-documenting.
  • The repository includes unit tests under tests/ that exercise tool-calling flows; run them with pytest.
  • Generated artifacts in build/ mirror the source package and inherit the same documentation updates.
  • Issues and pull requests are welcome; please run checks locally before submitting changes.

License

Licensed under the Apache License 2.0.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

easier_openai-7.1.1.tar.gz (30.1 kB view details)

Uploaded Source

Built Distribution

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

easier_openai-7.1.1-py3-none-any.whl (28.3 kB view details)

Uploaded Python 3

File details

Details for the file easier_openai-7.1.1.tar.gz.

File metadata

  • Download URL: easier_openai-7.1.1.tar.gz
  • Upload date:
  • Size: 30.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.4

File hashes

Hashes for easier_openai-7.1.1.tar.gz
Algorithm Hash digest
SHA256 9d2311035342206d537d09823955d2908c8f3b7ce6cd6a99ee3a45ed2ed85cd8
MD5 2a9a08997ec1eaf55d57f467b2ac3a3d
BLAKE2b-256 f979112fdaf25b3c837d5f923aa95c22b81f986e8f9cf7ea389283b9e00b70f5

See more details on using hashes here.

File details

Details for the file easier_openai-7.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for easier_openai-7.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4a7814d8ee773e4e400fe2114a75829161df328d0a7ef8ab50c56dfdd366a7e5
MD5 1af7475a32d283b0dce9015f0b2e1c9f
BLAKE2b-256 68e31574e133e60724a7b205475e46cdfe1e28df3ebdcec25446622195b40996

See more details on using hashes here.

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