A CLI tool to run Python scripts directly from GitHub URLs
Project description
Githrun
https://github.com/notamitgamer/githrun/blob/main/test/test_githrun.py
The Swiss Army Knife for Remote Python Execution.
It is available as a VS Code extension. Check out: marketplace.visualstudio.com
Githrun is a powerful CLI tool and Python library that lets you run, explore, and install Python code directly from GitHub and Gists. It handles dependencies, private repositories, and even turns remote scripts into local command-line tools.
Features
- Remote Execution: Run scripts from GitHub or Gist URLs instantly.
- Auto-Dependency Management: Automatically creates temporary virtual environments and installs missing packages using the
--auto-installflag. - Private Repo Access: Authenticate securely with GitHub tokens to access private code and increase API rate limits.
- Bookmarks: Save long URLs as short aliases (e.g.,
githrun run clean-db). - Tool Installation: Install remote scripts as permanent local CLI commands available in your system path.
- Recursive Downloads: Download entire folders or specific sub-directories from a repository.
- Interactive Search: Search for files in a repo and run them immediately from the results.
- Smart Caching: Caches API responses to speed up repeated searches and reduce API usage.
Installation
pip install githrun
CLI Usage
1. Run Remote Code
Execute a script directly from a URL.
Basic Execution:
githrun run [https://github.com/user/repo/blob/main/script.py](https://github.com/user/repo/blob/main/script.py)
Run Gists:
githrun run [https://gist.github.com/user/1234567890abcdef](https://gist.github.com/user/1234567890abcdef)
Auto-Install Dependencies: If a remote script requires packages you do not have installed (e.g., pandas, requests), use this flag to run it in an isolated environment:
githrun run [https://github.com/user/repo/blob/main/data.py](https://github.com/user/repo/blob/main/data.py) --auto-install
Inspect Code: View the source code with syntax highlighting before running it (Safety Check):
githrun run [https://github.com/user/repo/blob/main/script.py](https://github.com/user/repo/blob/main/script.py) --inspect
2. Authentication (Private Repos & Rate Limits)
GitHub limits unauthenticated requests to 60 per hour. Login to increase this limit to 5,000 and access private repositories.
githrun login ghp_YourPersonalAccessToken...
The token is stored securely in ~/.githrun/config.json.
3. Bookmarks
Stop copy-pasting long URLs. Save them once, run them anywhere.
Add a Bookmark:
githrun bookmark add clean-db [https://github.com/user/repo/blob/main/utils/cleanup.py](https://github.com/user/repo/blob/main/utils/cleanup.py)
Run a Bookmark:
githrun run clean-db
List Bookmarks:
githrun bookmark list
4. Install as a Tool
Turn a remote Python script into a command you can run from anywhere in your terminal.
githrun install [https://github.com/user/repo/blob/main/my-tool.py](https://github.com/user/repo/blob/main/my-tool.py) --name mytool
- Windows: Creates a
.batfile in~/.githrun/bin. - Linux/Mac: Creates an executable shim in
~/.githrun/bin. - Note: You must add
~/.githrun/binto your system PATH.
5. Find & Search
Search for files inside a remote repository without cloning it.
# Search for files containing "config"
githrun find [https://github.com/user/repo](https://github.com/user/repo) "config"
This command is interactive. You can select a result number to run it immediately.
6. Download Files & Folders
Download artifacts to your local machine.
Download a single file:
githrun download [https://github.com/user/repo/blob/main/script.py](https://github.com/user/repo/blob/main/script.py)
Download a specific folder (Recursive):
githrun download [https://github.com/user/repo/tree/main/src/utils](https://github.com/user/repo/tree/main/src/utils) --output ./local_utils
7. Show Folder Contents
List files in a remote directory to understand the structure.
githrun show [https://github.com/user/repo/tree/main/src](https://github.com/user/repo/tree/main/src)
Python API Usage
You can use Githrun inside your own Python scripts.
import githrun
# 1. Search a repository
results = githrun.search_repository("[https://github.com/user/repo](https://github.com/user/repo)", "test")
for item in results:
print(item['path'], item['raw_url'])
# 2. Download a file
githrun.download_file("[https://github.com/user/repo/blob/main/script.py](https://github.com/user/repo/blob/main/script.py)", output_path="script.py")
# 3. Download a full folder
githrun.download_folder("[https://github.com/user/repo/tree/main/src](https://github.com/user/repo/tree/main/src)")
# 4. Execute code programmatically
exit_code = githrun.execute_remote_code("[https://github.com/user/repo/blob/main/script.py](https://github.com/user/repo/blob/main/script.py)", args=["--verbose"])
Configuration
Githrun stores configuration and cache files in your home directory:
- Config:
~/.githrun/config.json(Tokens, Bookmarks) - Cache:
~/.githrun/cache/(API responses) - Binaries:
~/.githrun/bin/(Installed tools)
License
This project is licensed under the MIT License.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file githrun-0.1.1.tar.gz.
File metadata
- Download URL: githrun-0.1.1.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7112e900c5ccc97957a8dee0f0bb522aceb0d49ca301ceab40b12817684dff38
|
|
| MD5 |
93bced8d8caf99c6e105c151ccf0f0e7
|
|
| BLAKE2b-256 |
b5ae2c2823662e29ebb04b5676bcc854b029d4e2717c4211ea8b40a09c3c0b96
|
File details
Details for the file githrun-0.1.1-py3-none-any.whl.
File metadata
- Download URL: githrun-0.1.1-py3-none-any.whl
- Upload date:
- Size: 13.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b612b440b80654c910bf79803387a668576033a6a27b9507415c13118a5af4a
|
|
| MD5 |
2f56b42c1520f83aa5b902e7c0c55be5
|
|
| BLAKE2b-256 |
92730310f3109afb4bff735edcb5e42e8832546cf46e312f64b026e4cab0c5f3
|