This script interacts with OpenAI's GPT-3 or GPT-4 models to generate text completions based on given prompts. It provides options to use pre-defined prompts, files, or command outputs as input. The generated completion and input can be saved for future reference.
Before running the script, ensure that you have Python and the openai
Python package installed.
The script requires a configuration file named .openai_config
located in your home directory. This file should contain your OpenAI API key, the default model, and temperature in the following format:
[DEFAULT]
API_KEY = your_openai_api_key
MODEL = model_name
TEMPERATURE = temperature_value
To execute the script, navigate to the directory containing the script and run:
python gpt.py
The script supports several command line arguments:
--file
: Provide one or multiple filenames to use as input.--command-output
: Choose a command to run and use its output.--prompt
: Select a prompt by index.--model
: Model to use for the chat completion.--temperature
: Temperature to use for the chat completion.--confirm-send
: Automatically confirm sending the message without prompt.--model-selection
: Choose the GPT model to use without prompt.--list-saved
: List all saved input-output files and exit.--output
: Provide a custom path for saving the output.
You can add custom prompts by editing the prompts.example
file in your home directory. The prompts should be in a Python dictionary format, with the keys being the prompt names and the values being the prompt texts.
You can add commands to be used with the --command-output
argument by editing the commands
dictionary in the script. The keys should be the command names and the values should be the command to run in a list format.
The script contains several functions that handle different aspects of the CLI:
read_prompts()
: Reads prompts from a file namedprompts.example
located in the user's home directory and returns a dictionary of prompts.get_input_or_file_input()
: Parses command-line arguments and returns the input content and argument values.list_saved_files()
: Lists saved input-output files and returns the name of the selected file.select_prompt()
: Allows the user to select a prompt from a list of predefined prompts and returns the selected prompt.edit_message_in_vim(message)
: Opens the provided message in Vim for editing and returns the edited message.save_input_output(input_content, output_content)
: Saves input and output content to timestamped files in a.gpt
directory located in the user's home directory.main()
: Main function that orchestrates the script's workflow.
- The script reads the prompts from the
prompts.example
file. - It parses the command-line arguments and gets the input content.
- The user selects a prompt.
- The message is displayed, and the user can choose to send the message, edit it, or cancel the operation.
- The user selects the GPT model to use (GPT-3 or GPT-4).
- The script sends the message to the OpenAI API and receives the chat completion output.
- The input and output content are saved to timestamped files in the
.gpt
directory. - The user can choose to exit or continue with another input.
./gpt
Select a prompt:
0. commit_message_prompt
1. one_shot
2. document
3. debug
4. cover_letter
5. job_classifier
6. job_decider