Skip to main content

Constants and functions generated on-the-fly by ChatGPT.

Project description

Anycode

Anycode is a Python module that uses ChatGPT to automatically generate constants and functions based on their name.

Just import anycode and use its dynamically-generated attributs: anycode.PI is 3.141592, anycode.SAMPLE_10_NAMES is ['John', 'Jane', 'Adam', 'Eve', …], anycode.SAMPLE_ISBN is "978-1-56619-909-4" and so on.

This works on functions, too:

import anycode

anycode.fetch_wikipedia_article_intro("Angelina Mango")
# => "Angelina Mango is an Italian singer-songwriter. …"

anycode.get_random_number_between(1000, 2000)
# => 1241 (for example)

anycode.multiply(4, 5)
# => 20

anycode.say_hello("Baptiste")
# prints "Hello, Baptiste!"

You can also import anything from anycode:

from anycode import print_whatever
print_whatever()

Install

pip install anycode

Or with Poetry:

poetry add anycode

We support Python 3.9+.

Usage

Note: you need a valid OpenAI API key. See below how to configure it.

Any attribute written in UPPER_CASE is assumed to be a single value:

import anycode

print(anycode.PI)  # 3.141592...
print(anycode.SAMPLE_EAN13)  # 9780141036148
print(anycode.SAMPLE_ISBN)  # 978-1-56619-909-4

print(anycode.TWO + anycode.TWO)  # 4

print(anycode.ROT13_DICT)  # {'A': 'N', 'B': 'O', 'C': 'P', 'D': 'Q', 'E': 'R', ...}

print(anycode.TEN_RANDOM_QUOTES)  # ['The only way to do great work is to love what you do. - Steve Jobs', ...]

print(anycode.OPENAI_API_KEY)  # raises a GenerationException("Cannot generate code for 'OPENAI_API_KEY'")

If you prefer can also import from the module:

from anycode import HELLO, WORLD

print(HELLO + " " + WORLD)
# prints Hello World

Any other value is a function:

import anycode

type(anycode.say_goodbye)
# => <class 'function'>

anycode.say_goodbye("John")
# prints "Goodbye, John!"

[!TIP] Simple functions work, but for complex things ChatGPT often fails to generate valid code.

[!CAUTION] The generated code is executed on the same machine as your code, so do not use this in production.

Accessing a function initiates it, but it doesn’t generate any code. We only do so when it’s called for the first time, so we know how many arguments it should take. Further calls reuse the cached function.

Once a function has been generated, you can access ._openai_fn on it to get the ChatGPT-generated function and .openai_response to get the ChatGPT text response.

Exceptions

When OpenAI can’t generate a valid value, the module raises a GenerationException that you can inspect to understand what went wrong. Use its query attribute to get the query used to generate the code and openai_response to get the response text from OpenAI.

Cache

Values are cached so that when you use them a second time we don’t call OpenAI another time. You can delete a value from the cache with del:

import anycode

# This calls the OpenAI API
print(anycode.GITHUB_URL)

# This uses the cache
print(anycode.GITHUB_URL)

del anycode.GITHUB_URL

# This calls the OpenAI API again
print(anycode.GITHUB_URL)

You can dump all the generated code in a file to save it for future usage:

with open("mycode.py", "w") as f:
    anycode.dump(f)

This allows you to inspect and reuse the generated code without Anycode nor OpenAI API calls.

Configuration

OpenAI API key

By default Anycode takes the value of the OPENAI_API_KEY from your environment or from a .env file. You can also explicitly set it:

import anycode

anycode.set_openai_api_key("your-api-key")

# or from an environment variable
anycode.set_openai_api_key_from_env("MY_OPENAI_API_KEY")

The typical usage is quite low: to develop and test this entire project I used $0.02 of credit.

Advanced configuration

The OpenAI client can be directly accessed and modified:

from anycode.client import openai_client

openai_client.default_headers = {"x-foo": "true"}

License

Copyright © 2024 – Baptiste Fontaine. See the LICENSE file.

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

anycode-0.2.0.tar.gz (6.2 kB view details)

Uploaded Source

Built Distribution

anycode-0.2.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file anycode-0.2.0.tar.gz.

File metadata

  • Download URL: anycode-0.2.0.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for anycode-0.2.0.tar.gz
Algorithm Hash digest
SHA256 0fed266a705bee12b16bc70a39f5aa2132908063e0fcafefdccde1537e1a7418
MD5 830f5fc335e7ca971ddae3443375c6f7
BLAKE2b-256 58d70df7c58e74817221204583fbb58622f2a3172f19a57d57d2ebd07a1a7840

See more details on using hashes here.

File details

Details for the file anycode-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: anycode-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for anycode-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b17a60c094da9221ac2bc87a90749c80de7d876b8f2dde4413b0825c73808fc2
MD5 69ebc250e9ec4cad1c85f8898e068f49
BLAKE2b-256 809d701148c50a545b308bdcf70bbe3f27f9fe6ec77241fcb999ca8a1fe1b6d3

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