Skip to main content

A simple library for creating and manipulating chat and message objects for LLM applications

Project description

chat-object

doctest coverage license python version

A simple library for creating and managing chat objects and messages for LLM applications.

Installation

From PyPI:

pip install chat-object

From GitHub:

pip install git+https://github.com/fresh-milkshake/chat-object.git

Or from source:

git clone https://github.com/fresh-milkshake/chat-object.git
cd chat-object
pip install -e .

Quick Start

Basic Chat Usage

Create a chat object and add messages to it:

import openai
from chat_object import Chat, Message, Role

client = openai.OpenAI()

chat = Chat(
    Message(Role.System, "You are a helpful assistant"),
    Message(Role.User, "Hello!")
)

response = client.chat.completions.create(
    model="gpt-5-nano",
    messages=chat.as_dict()
)

print(response.choices[0].message.content)

Using the Prompt Class

The Prompt class automatically handles indentation and formatting:

from chat_object import Prompt

# Clean indentation automatically
prompt = Prompt("""
    You are a helpful assistant.
    Please help me with the following task:
    
    def example_function():
        return "hello world"
    
    Explain what this function does.
""")

# Multiple arguments are joined with newlines
prompt = Prompt(
    "You are a helpful assistant.",
    "Please be concise in your responses.",
    "Focus on practical solutions."
)

# String operations work naturally
prompt += "\n\nAdditional context here"

QOL Features for Quick Development

Use convenience functions for faster development:

from chat_object import chat, msg_user, msg_system, msg_assistant, prmt

# Quick chat creation
chat_obj = chat(
    msg_system("You are a helpful assistant."),
    msg_user("Hello!"),
    msg_assistant("Hi there! How can I help you today?")
)

# Quick prompt creation
prompt = prmt("You are a helpful assistant.")

# Convert to dict for API calls
messages = chat_obj.as_dict()

[!TIP] See examples folder for more comprehensive examples.

Features

  • Well-tested code: Comprehensive test coverage with doctests throughout the codebase (90% coverage)
  • Type safety: Full type hints and enum-based roles
  • Backward compatibility: seamless integration with existing APIs like OpenAI, Anthropic, Together, Ollama, etc.
  • QOL features: Quick and easy message creation with msg_user, msg_assistant, msg_system, prmt, msgs, chat (Recommended, but not required). Pretty rich example usage of qol features is in examples/openai_use_case.py.

License

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

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

chat_object-2.0.0.tar.gz (11.5 kB view details)

Uploaded Source

Built Distribution

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

chat_object-2.0.0-py3-none-any.whl (12.5 kB view details)

Uploaded Python 3

File details

Details for the file chat_object-2.0.0.tar.gz.

File metadata

  • Download URL: chat_object-2.0.0.tar.gz
  • Upload date:
  • Size: 11.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.4

File hashes

Hashes for chat_object-2.0.0.tar.gz
Algorithm Hash digest
SHA256 04996ea046e6a830fc516764120704d7c6d6550adc6d255171f29937542e7a53
MD5 3037eeefe6c895847202cc6d62a2d33d
BLAKE2b-256 bd2c35dbc43e1e4b6a756f07333b3640f083badeb02992d896011c95e24ddfdc

See more details on using hashes here.

File details

Details for the file chat_object-2.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for chat_object-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d973ffe076777952065c6e53f4170255aeda5381f082c03f2ebec026fa44e945
MD5 61c581378928ab8a7c389a6675935e5d
BLAKE2b-256 b3b18be0ea8e8a67036cdb9538f693b452d1361357aaf090b4dad484ea6c6596

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