A flexible command-line interface for interacting with various AI language models, supporting multiple providers and customizable output formats.
NOTE: This is a very work in progress project and may break at any time.
- Can be run in basic LLM mode or agent mode that can use tools
- Shows pricing info when requested
- Support for multiple AI providers (OpenAI, Anthropic, Groq, Google, Ollama, Bedrock)
- Support for custom output formats Markdown, CSV, etc.
- Support for custom context sources stdin, file, url, and web search
- Python 3.11+
- Rich for terminal output
- Typer for CLI interface
- Support for multiple AI providers (OpenAI, Ollama, Bedrock)
- Uses my PAR AI Core
- Python 3.11 or higher
- UV package manager
- API keys for chosen AI provider (except for Ollama and LlamaCpp)
- See provider-specific documentation for required API key environment variables
- If you want to use image or audio features ensure you install ffmpeg
- If you want to use audio features you may need portaudio installed
Note: Installation of ffmpeg might not actually be needed to operate RealtimeSTT *thanks to jgilbert2017 for pointing this out
You can download an installer for your OS from the ffmpeg Website.
Or use a package manager:
-
On Ubuntu or Debian:
sudo apt update && sudo apt install ffmpeg
-
On Arch Linux:
sudo pacman -S ffmpeg
-
On MacOS using Homebrew (https://brew.sh/):
brew install ffmpeg
-
On Windows using Winget official documentation :
winget install Gyan.FFmpeg
-
On Windows using Chocolatey (https://chocolatey.org/):
choco install ffmpeg
-
On Windows using Scoop (https://scoop.sh/):
scoop install ffmpeg
-
On Linux:
sudo apt-get update sudo apt-get install portaudio19-dev
-
On MacOS:
brew install portaudio
git clone https://github.com/paulrobello/par_gpt.git
cd par_gpt
uv tool install .
uv tool install git+https://github.com/paulrobello/par_gpt
cd par_gpt
git pull
uv tool install -U --force .
uv tool install -U --force git+https://github.com/paulrobello/par_gpt
par_gpt [OPTIONS]
--ai-provider -a [Ollama|LlamaCpp|OpenAI|Groq|XAI|
Anthropic|Google|Bedrock|Github|Mistral] AI provider to use for processing [env var: PARGPT_AI_PROVIDER] [default: OpenAI]
--model -m TEXT AI model to use for processing. If not specified, a default model will be used. [env var: PARGPT_MODEL] [default: None]
--light-model -l Use a light model for processing. If not specified, a default model will be used. [env var: PARGPT_LIGHT_MODEL]
--ai-base-url -b TEXT Override the base URL for the AI provider. [env var: PARGPT_AI_BASE_URL] [default: None]
--temperature -t FLOAT Temperature to use for processing. If not specified, a default temperature will be used. [env var: PARGPT_TEMPERATURE] [default: 0.5]
--user-agent-appid -U TEXT Extra data to include in the User-Agent header for the AI provider. [env var: PARGPT_USER_AGENT_APPID] [default: None]
--pricing -p [none|price|details] Enable pricing summary display [env var: PARGPT_PRICING] [default: none]
--display-output -d [none|plain|md|csv|json] Display output in terminal (none, plain, md, csv, or json) [env var: PARGPT_DISPLAY_OUTPUT] [default: md]
--context-location -f TEXT Location of context to use for processing.
--system-prompt -s TEXT System prompt to use for processing. If not specified, a default system prompt will be used. [default: None]
--user-prompt -u TEXT User prompt to use for processing. If not specified, a default user prompt will be used. [default: None]
--max-context-size -M INTEGER Maximum context size when provider supports it. 0 = default. [env var: PARGPT_MAX_CONTEXT_SIZE] [default: 0]
--copy-to-clipboard -c Copy output to clipboard
--copy-from-clipboard -C Copy context or context location from clipboard
--debug -D Enable debug mode [env var: PARGPT_DEBUG]
--show-config -S Show config [env var: PARGPT_SHOW_CONFIG]
--version -v
--help Show this message and exit.
show-env Show environment context.
llm Basic LLM mode with no tools.
git Git commit helper.
code-review Review code.
generate-prompt Use meta prompting to generate a new prompt.
agent Full agent with dynamic tools.
--max-iterations -i INTEGER Maximum number of iterations to run when in agent mode. [env var: PARGPT_MAX_ITERATIONS] [default: 5]
--show-tool-calls -T Show tool calls [env var: PARGPT_SHOW_TOOL_CALLS]
--yes-to-all -y Yes to all prompts [env var: PARGPT_YES_TO_ALL]
--repl Enable REPL tool [env var: PARGPT_REPL]
# AI API KEYS
OPENAI_API_KEY=
ANTHROPIC_API_KEY=
GROQ_API_KEY=
XAI_API_KEY=
GOOGLE_API_KEY=
MISTRAL_API_KEY=
GITHUB_TOKEN=
# Search
GOOGLE_CSE_ID=
GOOGLE_CSE_API_KEY=
SERPER_API_KEY=
SERPER_API_KEY_GOOGLE=
TAVILY_API_KEY=
JINA_API_KEY=
BRAVE_API_KEY=
REDDIT_CLIENT_ID=
REDDIT_CLIENT_SECRET=
# Misc api
WEATHERAPI_KEY=
GITHUB_PERSONAL_ACCESS_TOKEN=
### Tracing (optional)
LANGCHAIN_TRACING_V2=false
LANGCHAIN_ENDPOINT=https://api.smith.langchain.com
LANGCHAIN_API_KEY=
LANGCHAIN_PROJECT=par_gpt
# Application Options
PARGPT_AI_PROVIDER=OpenAI
PARGPT_MODEL=# if blank, strong model default will be used
PARGPT_PRICING=price # none | price | details
PARGPT_DISPLAY_OUTPUT=md
PARGPT_DEBUG=false
PARGPT_SHOW_CONFIG=false
PARGPT_AGENT_MODE=false # if this is false par_gpt will only use basic LLM completion
PARGPT_REPL=false # set this to true to allow agent to WRITE and EXECUTE CODE ON HOST MACHINE
PARGPT_CODE_SANDBOX=false # set this to true to allow agent to write and execute code in a secure docker container sandbox
PARGPT_MAX_ITERATIONS=5 # maximum number of iterations to allow when in agent mode. Tool calls require iterations
PARGPT_YES_TO_ALL=false # set this to true to skip all confirmation prompts
PARGPT_SHOW_TOOL_CALLS=true
- ANTHROPIC_API_KEY is required for Anthropic. Get a key from https://console.anthropic.com/
- OPENAI_API_KEY is required for OpenAI. Get a key from https://platform.openai.com/account/api-keys
- GITHUB_TOKEN is required for GitHub Models. Get a free key from https://github.com/marketplace/models
- GOOGLE_API_KEY is required for Google Models. Get a free key from https://console.cloud.google.com
- XAI_API_KEY is required for XAI. Get a free key from https://x.ai/api
- GROQ_API_KEY is required for Groq. Get a free key from https://console.groq.com/
- MISTRAL_API_KEY is required for Mistral. Get a free key from https://console.mistral.ai/
- AWS_PROFILE or AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY are used for Bedrock authentication. The environment must already be authenticated with AWS.
- No key required to use with Ollama or LlamaCpp.
- TAVILY_API_KEY is required for Tavily AI search. Get a free key from https://tavily.com/. Tavily is much better than
- JINA_API_KEY is required for Jina search. Get a free key from https://jina.ai
- BRAVE_API_KEY is required for Brave search. Get a free key from https://brave.com/search/api/
- SERPER_API_KEY is required for Serper search. Get a free key from https://serper.dev
- SERPER_API_KEY_GOOGLE is required for Google Serper search. Get a free key from https://serpapi.com/
- GOOGLE_CSE_ID and GOOGLE_CSE_API_KEY are required for Google search.
- REDDIT_CLIENT_ID and REDDIT_CLIENT_SECRET are needed for Reddit search. Get a free key from https://www.reddit.com/prefs/apps/
- GITHUB_PERSONAL_ACCESS_TOKEN is required for GitHub related tools. Get a free key from https://github.com/settings/tokens
- WEATHERAPI_KEY is required for weather. Get a free key from https://www.weatherapi.com/
- LANGCHAIN_API_KEY is required for Langchain / Langsmith tracing. Get a free key from https://smith.langchain.com/settings
NOTE: Agent mode enables tool use.
Some tools require API keys to be available and various keywords in your request to present to be enabled.
If the REPL tool is enabled the Code sandbox tool will not be used.
- REPL - Allows the AI to WRITE AND EXECUTE CODE ON YOUR SYSTEM.
The REPL tool must be manually enabled. If the REPL tool is used it will prompt you before executing the code. Unless you specify --yes-to-all. - Code sandbox - Allows AI to write and execute code in a secure docker sandbox container which must be setup separately. The Code sandbox tool must be manually enabled.
- Open URL - Opens a URL in the default browser.
- Fetch URL - Fetches the content of one or more webpages and returns as markdown.
- Show image in terminal - Displays low resolution image in terminal sized based on terminal dimensions.
- Figlet - Displays Figlet style text in terminal.
- Youtube search - Search youtube and get video info.
- Youtube transcript - Get youtube transcript for video.
- Hacker News - Fetch top posts from HackerNews.
- Git - Allows interaction with local git repos.
- Tavily search - Search web and get scraped web results.
- Serper search - Search web using serper.
- Google search - Search web using google.
- Brave search - Search web using brave search.
- Reddit search - Search reddit and get posts and optionally comments.
- Clipboard - Allows copy to and from clipboard.
- RSS - Fetch RSS feed content.
- Weather - Fetch weather info.
- Github - Allows creation, publishing to and listing of personal Github repos.
The code sandbox allows the AI agent mode to write and execute code safely contained in a docker container.
To use the sandbox you must have docker
and make
installed as well as build and run the sandbox container.
Sandbox setup steps:
git clone https://github.com/paulrobello/par_gpt.git
cd par_gpt
make sandbox
Code review mode sends code related files to AI for review. The review looks for bugs and issues in the code and provides a ranking of severity as well as suggestions for how to fix them.
Change to the root of the project you want to check (or sub folder for smaller / faster / more cost-effective checks) and run the following:
par_gpt code_review
# Basic usage with stdin
echo "What is Python?" | par_gpt llm
# Use a the light model with custom temperature
par_gpt --light-model -t 0.7 llm "Explain quantum computing"
# Use Ollama with local models Note: you must have qwen2:latest pulled
par_gpt -a ollama -m qwen2:latest llm "Write a haiku"
# get 3d printer filament grade and properties from youtube then generate a sorted table and save to Obsidian vault.
# this example uses other commands that may not be available on your system however does showcase can it can be chainable
par_yt2text --transcript 'https://www.youtube.com/watch?v=weeG9yOp3i4' | \
par_gpt -p "use the transcript in the context and create a markdown table with 3 columns 'filament_name', 'properties' and 'grade' generate the table based on the feedback from the transcript" llm | \
par_gpt llm "sort the table by grade in the following order S,A,B,C,F" | \
save_vault fillament_grade_props
# get commit message for current changes
par_gpt git 'display commit message for current changes'
# commit current changes with automatically generated commit message also show config and pricing
par_gpt --show-config --pricing details git 'commit current changes'
# copy commit message for current changes to clipboard using agent mode
par_gpt -t 0 --debug agent 'create a commit messages that would be relevant to the changes in the current repository and copy to clipboard'
# get details for new Macbook M4 Max (this will use web search and web scrape tools)
par_gpt agent 'get me the details for the new Macbook M4 Max'
# generate a csv file named data.csv filled with fake names and ages
par_gpt agent 'generate a csv file named data.csv filled with fake names and ages'
# read csv file named data.csv and generate a PNG format image graph with age on the x axis and count of age on y axis. open the PNG in a browser
par_gpt agent 'read csv file named data.csv and generate a PNG format image graph with age on the x axis and count of age on y axis. open the PNG in a browser'
# read csv file named data.csv and generate a graph with age on the x axis and count of age on y axis. display the image in the terminal
par_gpt agent 'read csv file named data.csv and generate a graph.png graph with age on the x axis and count of age on y axis. display the image in the terminal size large'
# display the current weather in Woodland CA
par_gpt agent 'current weather in Woodland CA and display the current conditions image / icon in the terminal'
par_gpt -p details -a OpenAI -d md agent --repl 'what is the value of 4 times the ArcTangent of 1'
# tell me a joke using github model on azure
par_gpt --show-config --debug -p -a Github -m "Llama-3.2-90B-Vision-Instruct" llm "tell me a joke"
par_gpt --show-config --debug -p -a Github -m "gpt-4o" llm "tell me a joke"
# Groq vision model
par_gpt -a Groq -m 'llama-3.2-90b-vision-preview' -f PATH_TO_IMAGE llm "describe this image"
# get image from url and answer question
par_gpt -f "https://gratisography.com/wp-content/uploads/2024/10/gratisography-birthday-dog-sunglasses-1036x780.jpg" llm "describe the image"
# Get context from url and answer question about it. Note does not currently use RAG so can be token heavy
par_gpt -p details -f 'https://console.groq.com/docs/vision' llm "what model ids support vision"
# get image from url and answer question
par_gpt -p details -f 'https://freerangestock.com/sample/157314/mystical-glowing-mushrooms-in-a-magical-forest.jpg' llm "describe this image"
# check code for bugs (change to root for project you want to check)
par_gpt code_review
- Version 0.6.0:
- Added support for TTS output
- Added screenshot support
- Aider support removed (too many dependency conflicts)
- Version 0.5.0:
- Added Aider command for code editing
- Version 0.4.0:
- Reworked sub commands and cli options
- Version 0.3.0:
- Added support for LlamaCPP (use base_url and run llamacpp in option ai server mode)
- Added code review agent
- Added prompt generation agent (work in progress)
- Updated pricing data
- Lots of bug fixes and improvements
- Version 0.2.1:
- Removed --context-source cli option as it is now auto-detected
- When working with images and model is not specified a suitable vision model will be selected
- added options to copy context from clipboard and results to clipboard
- Version 0.2.0:
- Added confirmation prompt for agent mode REPL tool
- Added yes-to-all flag to skip confirmation prompts
- Updated pricing data
- Version 0.1.0:
- Initial release
Contributions are welcome! Please feel free to submit a Pull Request. Before contributing:
- Ensure you have Python 3.11+
- Use UV for dependency management
- Follow the existing code style
- Update documentation as needed
This project is licensed under the MIT License - see the LICENSE file for details.
Paul Robello - [email protected] GitHub: paulrobello