Skip to main content

A comprehensive wrapper for the OpenAI API, facilitating seamless interaction with GPT models. Features include conversation management, dynamic function execution, and tools for creating JSON schemas for function descriptions. Simplifies setting API keys and managing chat contexts for enhanced GPT-based applications.

Project description

OpenAI Unlimited Function Wrapper

The openaiunlimitedfuncwrapper is a Python package that simplifies interaction with the OpenAI API, providing easy access to various models of GPT, including conversational capabilities, dynamic function calling, and pseudo-function execution to elicit specific responses based on parameter modification.

Features

  • Single-question querying to any GPT model and receiving a response.
  • Engaging in a conversation with context management.
  • Dynamically adding callable functions within the code.
  • Forcing execution of real or pseudo-functions to steer responses.
  • Automatic and manual creation of JSON schemas for function descriptions.
  • Setting the OpenAI API key via code for environment preparation.

Installation

To install openaiunlimitedfuncwrapper, simply run:

pip install openaiunlimitedfun

Setting Up Your OpenAI API Key

Before you start using the package, you need to set your OpenAI API key. You can do this by running:

from openaiunlimitedfun import set_openai_api_key

set_openai_api_key('your-api-key-here')

This will create or append to a .env file in your current directory, storing your API key.

Managing Available Functions

To make custom functions available for the OpenAI API to call during a conversation, use the manage_available_functions function:

from openaiunlimitedfun import manage_available_functions

# To save current module's functions
manage_available_functions(retrieve=False)

# To retrieve available functions
functions = manage_available_functions()

Adding Functions to the Function List

If you want to add specific functions to be accessible during the conversation, use manage_function_list:

from openaiunlimitedfun import manage_function_list

# To add a function to the list
manage_function_list(function_to_add='your_function_name')

# To retrieve the list of functions
function_list = manage_function_list(retrieve=True)

Generating JSON Schemas for Functions

You can create JSON schemas for your functions automatically or manually. This can be used to generate function descriptions for use within the wrapper.

Automatic JSON Schema Generation

Automatically generate a JSON schema based on user input:

from openaiunlimitedfun import create_json_autoagent

schema = create_json_autoagent('Describe a function that calculates the sum of two numbers.')
print(schema)

Manual JSON Schema Creation

Manually create a JSON schema through an interactive prompt:

from openaiunlimitedfun import create_function_json_manual

create_function_json_manual()
# Follow the interactive prompts to create your function JSON schema.

Usage Examples

Single Question

Query a single question and get a response:

from openaiunlimitedfun import single_question

response = single_question("What is the capital of France?")
print(response)

Conversational Context

Engage in a conversation with the ability to maintain context:

from openaiunlimitedfun import chat_context_function_bank

question = "Who wrote the play Hamlet?"
context = []  # This should be a list of previous messages if you have them

response, updated_context = chat_context_function_bank(question, context)
print(response)

Pseudo-Function Execution

Force the execution of a pseudo-function to get a desired response:

from openaiunlimitedfun import single_turn_pseudofunction

# Define a pseudo-function
pseudo_function = {
    "name": "calculate_sum",
    "parameters": {
        "number1": 5,
        "number2": 3
    }
}

# Use the pseudo-function in a prompt
response = single_turn_pseudofunction("What is the sum of the numbers?", pseudo_function)
print(response)

Contributing

Contributions are welcome! Please feel free to submit pull requests, report bugs, and suggest features.

License

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

Build

  • If you want to run a new pip build make sure to actiavte an enviroment, run pip install -r requirement.txt
  • Then be sure to run Remove-Item -Recurse -Force build, dist, *.egg-info if you had run a build before, else it would return an error
  • Then run python setup.py sdist bdist_wheel

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

openaiunlimitedfun-0.1.1.tar.gz (11.1 kB view details)

Uploaded Source

Built Distribution

openaiunlimitedfun-0.1.1-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file openaiunlimitedfun-0.1.1.tar.gz.

File metadata

  • Download URL: openaiunlimitedfun-0.1.1.tar.gz
  • Upload date:
  • Size: 11.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for openaiunlimitedfun-0.1.1.tar.gz
Algorithm Hash digest
SHA256 6c2b9e22694199346627bd11d2b8a0247c7526f55cfc77064f9978951f3c95c0
MD5 cb571075df60fd92bd10e9f42f8037fa
BLAKE2b-256 ea78862a8a48816f9c3bcb4d20bafd95075532353defa343c8d42c1dec9bb8aa

See more details on using hashes here.

File details

Details for the file openaiunlimitedfun-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for openaiunlimitedfun-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 75fa048c355151d398f03b581f040dbac9015387bf6ab7859ca1482556dd8917
MD5 60e7712160a399348b62205967535d8b
BLAKE2b-256 7c8eb49feb2d716497cb4e4369f96babf4948a367b9eaca825272f523bb38bea

See more details on using hashes here.

Supported by

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