A Python package that generates complex Python projects and fixes errors in your code using OpenAI's GPT API.
Project description
ScriptMonkey 🐒
ScriptMonkey is an AI-powered Python package that reimagines how projects are built. It doesn’t just generate simple scripts or templates like traditional LLMs—it creates entire, multi-file, multi-directory projects with fully custom code. Complex Python projects can be generated in seconds based on your natural language descriptions, providing everything you need, from models and routes to templates and configuration files. With ScriptMonkey, you can instantly bootstrap new ideas or start complex projects without the tedious setup. And with built-in error detection and automatic fixes, ScriptMonkey keeps your development process smooth and stress-free, letting you focus on what matters most: building.
Features
- Custom Project Generation: Create entire Python projects, not just boilerplate code. ScriptMonkey generates the specific files and directories you need based on your description.
- Lightning-Fast Setup: Complex Python projects can be generated in seconds, saving you time and effort.
- Automatic Error Detection: Captures errors during runtime.
- AI-Powered Fixes: Uses OpenAI's GPT API to understand and resolve errors.
- Code Auto-Correction: Automatically updates your Python files with the fixes.
- Cross-IDE Compatibility: Works with any IDE or code editor.
Installation
To install ScriptMonkey, simply run:
pip install scriptmonkey
Usage
Project Generation with python3 -m scriptmonkey
ScriptMonkey can generate a complete, custom-coded project structure based on a description you provide. This feature helps you quickly set up new projects with the necessary files and folders.
How to Use
-
Run the following command in your terminal:
python3 -m scriptmonkey
-
A text editor will open (e.g.,
nano
,vim
, ornotepad
depending on your environment). Follow the on-screen instructions to provide a detailed description of your project. -
Save and close the editor. ScriptMonkey will then:
- Generate a complete project structure based on your description.
- Create directories, code files, and templates.
- Automatically generate a
README.md
with installation instructions and usage details.
Example Project Description Prompt
I need a Flask-based web application for managing a book library. The application should include:
- User authentication (login, registration, password reset).
- Models for Users, Books, and Authors using SQLAlchemy.
- A REST API with routes for adding, updating, and deleting books and authors.
- An admin dashboard for managing users and viewing statistics.
- HTML templates for user login, book list, and book detail views.
- The database should use PostgreSQL.
- Include environment-specific configurations for development and production.
ScriptMonkey will use this description to create a project structure and code files for you in a directory named generated_project
.
Error Handling with scriptmonkey.run()
ScriptMonkey doesn't just build projects; it also makes debugging a breeze.
- Import
scriptmonkey
in your Python script. - Call
scriptmonkey.run()
to activate the error handler. - Run your code, and let ScriptMonkey handle any errors that occur.
Example
import scriptmonkey
# Enable ScriptMonkey's error handler
scriptmonkey.run()
# Intentional error for testing
def add(a, b):
return a + b # This will fail if b is a string
print(add(2, "3")) # ScriptMonkey will automatically fix this error and update the file.
Once an error occurs, ScriptMonkey will:
- Detect the error.
- Send the error and code to OpenAI for analysis.
- Provide a solution and automatically update the file with the corrected code.
Setting or Updating Your OpenAI API Key
If you haven't set your OpenAI API key yet or need to update it, you can do so with the following command:
python3 -m scriptmonkey --set-api-key your-api-key
This will store the API key in a config locally and use it for all future interactions with OpenAI.
Requirements
- Python 3.6 or later
- An OpenAI API key (follow the steps below if you don't have one)
Obtaining an OpenAI API Key
- Go to the OpenAI website: OpenAI Platform
- Sign up or log in to your account.
- Navigate to the API keys section in your account dashboard.
- Create a new API key and copy it.
Configuring the API Key for ScriptMonkey
-
Option 1: Environment Variable
You can set up your API key as an environment variable:export OPENAI_API_KEY='your-api-key'
-
Option 2: Entering the API Key When Prompted
If ScriptMonkey does not find an API key in your environment variables, it will prompt you to enter your key. Once entered, it will save the key to a configuration file for future use. -
Option 3: Using the
--set-api-key
Command
Use the--set-api-key
command as shown above to set or update your API key easily.
Let ScriptMonkey take care of your Python errors and project setup so you can focus on building!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file scriptmonkey-1.0.0.tar.gz
.
File metadata
- Download URL: scriptmonkey-1.0.0.tar.gz
- Upload date:
- Size: 12.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3c335c523357f448afb56e46c1e6de03e00b379667d179c9f8d8c95cb9e66592 |
|
MD5 | ecb6ae4fc58fde597f131abb7bb86f00 |
|
BLAKE2b-256 | d318f4c041283c81a973279870b51f4158615d654f0de85582a5d800ef350023 |
File details
Details for the file scriptmonkey-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: scriptmonkey-1.0.0-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 49eb45d62565fee991c00cc5911b31da3013b427d6435df7a54b6926e7084e02 |
|
MD5 | 0b95bf94faca25240239f34c6b8e0009 |
|
BLAKE2b-256 | 7e82e213eeb8af0b6fcc6c24424a20ff4568d60aa98df263e0ff5bb4bcdd7192 |