GitXplorerGitXplorer
s

openai-decorator

public
7 stars
3 forks
0 issues

Commits

List of commits on branch main.
Verified
fc15408edb51aef24e96973157d2906a468e365b

Add ability to specify the type of function call parameter to use (#13)

sshruti222patel committed 2 years ago
Verified
de1590813204c10c1da64973e38b87f73e3b6c69

Version bump to 0.1.3 (#12)

sshruti222patel committed 2 years ago
Verified
efb279c0b7c56bff304081a24de2e4ebef8c2085

Ensure all python versions from 3.8 onwards are compatible with this library (#11)

sshruti222patel committed 2 years ago
Unverified
1c39267942124402c7198e8453d9a2d5520d933c

Add keywords

sshruti222patel committed 2 years ago
Unverified
185ef6de0ee56cea424af6c053c8d89cdc08e0cd

Bump version

sshruti222patel committed 2 years ago
Verified
8c2957850a7523f6d783f885a1202d73ce5cf1ec

Test py versions (#10)

sshruti222patel committed 2 years ago

README

The README file for this repository.

OpenAI Decorator

The OpenAI Decorator is a Python package that enriches your Python functions with the capabilities of OpenAI's API. It leverages the function's signature and docstring to generate specifications comprehensible by OpenAI's API, subsequently making a request to the API.

Table of Contents

Key Features

  • Automatic generation of specs from the function's signature and docstring.
  • Integration with OpenAI's API using the generated specs and a customizable prompt.
  • Inference of function arguments from the OpenAI API response, negating the need for manual input.
  • Handling of various edge cases related to function signatures, including default and optional values.

Installation

Install the package using pip:

pip install openai-decorator

Save your OpenAI key in an environment variable named OPENAI_API_KEY:

export OPENAI_API_KEY=<your key>

Usage Guide

Basic Usage

Apply the openai_func decorator to a function with type annotations and a well-formatted Google Style docstring. Then, it will seamlessly interact with OpenAI's API to generate the parameters for your function based on the prompt.

from openai_decorator import openai_func

@openai_func(prompt="Your OpenAI prompt here")
def example_function(arg1: str, arg2: int) -> str:
    """
    This is an example function.

    Args:
        arg1 (str): Description for arg1
        arg2 (int): Description for arg2

    Returns:
        str: Description for return value
    """
    return f"Your output here: {arg1} and {arg2}"

result = example_function()
print(result)

Type Annotations & Optionals

The decorator efficiently handles complex function signatures:

  • Default Values: Parameters with a default value or Optional type annotation are marked as optional in the JSON specification.
  • Type Annotations: Supports primitive types (int, str, bool, float) and complex types (List, Dict, Tuple, Set, Optional, custom classes).
from openai_decorator import openai_func

@openai_func(prompt="Perform mathematical operations")
def example_function(a: int, b: int, c: float = 0.0, d: List[int] = []):
    """
    This is an example function.

    Args:
        a: The first integer.
        b: The second integer.
        c: An optional float.
        d: An optional list of integers.
    """
    # Function body here

Passing Callable Prompts

In addition to static strings, you can also pass a callable to the prompt parameter in the openai_func decorator to dynamically generate prompts. This callable should take no arguments and return a string. Here's an example:

from openai_decorator import openai_func

def generate_prompt():
    # Dynamically generate a prompt.
    # In a real-world scenario, this could depend on various factors,
    # such as the current time or the latest trending topics.
    return "Your OpenAI prompt here"

@openai_func(prompt=generate_prompt)
def example_function(arg1: str, arg2: int) -> str:
    """
    This is an example function.

    Args:
        arg1 (str): Description for arg1
        arg2 (int): Description for arg2

    Returns:
        str: Description for return value
    """
    return f"Your output here: {arg1} and {arg2}"

result = example_function()
print(result)

In this example, every time example_function is called, `generate_prompt

Using the Decorator as a Regular Function

openai_func can also be used as a regular function. First, call openai_func with the prompt and any other arguments to get the actual decorator. Then, apply this decorator to your function.

from openai_decorator import openai_func

def example_function(arg1: str, arg2: int) -> str:
    """
    This is an example function.

    Args:
        arg1 (str): Description for arg1
        arg2 (int): Description for arg2

    Returns:
        str: Description for return value
    """
    return f"Your output here: {arg1} and {arg2}"

# Use openai_func as a regular function
prompt = "Your OpenAI prompt here"

example_func_with_generated_params = openai_func(prompt=prompt)(example_function)

result = example_func_with_generated_params()
print(result)

This approach gives you more flexibility in determining the prompt at runtime.

Contributing

Contributions are welcome! Feel free to submit issues and pull requests.

Setup

  1. Install Python 3.11 and the latest version of poetry
    • pyenv can help manage multiple Python versions.
  2. Clone the repository: git clone.
  3. Set your OpenAI key as an environment variable:
export OPENAI_API_KEY=<insert your openai key>
  1. Install dependencies: poetry install --no-root

Future Enhancements

  • [x] Handle optional parameters.
  • [x] Handle parameters with default values.
  • [ ] Add test to ensure default values are used if OpenAI doesn't return parameters.
  • [ ] Publish the package to PyPI.
  • [ ] Expand test coverage.
  • [ ] Show tests passing & coverage as github badges.
  • [X] Fix CI/CD -- Address the issue where the pre-release deployment to PyPI fails due to the need for version update.
  • [ ] Add docstrings.
  • [ ] Generate docs (from docstrings).

License

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