galaxy-cli is a Python CLI and REPL for automating the
Galaxy bioinformatics platform from the shell. It
wraps the Galaxy REST API for histories, datasets, collections, tools,
workflows, jobs, and libraries.
This project was initially generated with cli-anything and then refined into
the standalone galaxy-cli package.
pip install galaxy-cligalaxy-cli is a Galaxy bioinformatics CLI for users who want a Galaxy
command-line client that works naturally in shell scripts and reproducible
Galaxy analyses. You can use it to:
- run Galaxy workflows from the command line and submit individual Galaxy tools
- upload and download datasets
- create and manage histories and collections
- inspect jobs, logs, tools, and workflow metadata
- automate Galaxy workflows for reproducible Galaxy bioinformatics analyses
- Python 3.9+
- A running Galaxy server
- A Galaxy API key from your target instance
Install from PyPI with uv or pip:
uv tool install galaxy-clipip install galaxy-cliFor local development from this repository:
python3 -m pip install .Verify installation:
which galaxy-cli
galaxy-cli --versionSet your Galaxy server URL and API key:
export GALAXY_URL=https://usegalaxy.org
export GALAXY_API_KEY=your-api-key
galaxy-cli config testSession state is stored in ~/.galaxy-cli/session.json. It is intended for a
single active writer; for parallel automation or multiple concurrent agents,
pass --history-id explicitly instead of relying on shared session state.
Documentation site: https://qchiujunhao.github.io/galaxy-cli/
galaxy-cli history list
galaxy-cli history create "My Analysis"
galaxy-cli tool search "bowtie"
galaxy-cli workflow list
galaxy-cli workflow list | jq .
galaxy-cli --human config showgalaxy-cli defaults to compact JSON output. Use --human for
human-readable terminal output.
Run the REPL:
galaxy-clipython3 -m pytest galaxy_cli/tests/ -vReleases are published from GitHub Releases through PyPI Trusted Publishing. See RELEASE.md for the one-time PyPI setup and release checklist.