A Python Integration for Transloadit's file uploading and encoding service.
Project description
Transloadit python-sdk
A Python Integration for Transloadit's file uploading and encoding service.
Intro
Transloadit is a service that helps you handle file uploads, resize, crop and watermark your images, make GIFs, transcode your videos, extract thumbnails, generate audio waveforms, and so much more. In short, Transloadit is the Swiss Army Knife for your files.
This is a Python SDK to make it easy to talk to the Transloadit REST API.
Only Python 3.9+ versions are supported.
Install
pip install pytransloadit
Usage
from transloadit import client
tl = client.Transloadit('TRANSLOADIT_KEY', 'TRANSLOADIT_SECRET')
assembly = tl.new_assembly()
assembly.add_file(open('PATH/TO/FILE.jpg', 'rb'))
assembly.add_step('resize', '/image/resize', {'width': 70, 'height': 70})
assembly_response = assembly.create(retries=5, wait=True)
print(assembly_response.data.get('assembly_id'))
# or
print(assembly_response.data['assembly_id'])
Example
For fully working examples, take a look at examples/.
Documentation
See readthedocs for full API documentation.
Contributing
Running tests
You can mirror our GitHub Actions setup locally by running the test matrix inside Docker:
scripts/test-in-docker.sh
This script will:
- build images for the Python versions we test in CI (3.9–3.13)
- install Poetry, Node.js 20, and the Transloadit CLI
- pass credentials from
.env(if present) so end-to-end tests can run against real Transloadit accounts
Signature parity tests use npx transloadit smart_sig under the hood, matching the reference implementation used by our other SDKs. Our GitHub Actions workflow also runs the E2E upload against Python 3.12 on every push/PR using a dedicated Transloadit test account (wired through the TRANSLOADIT_KEY and TRANSLOADIT_SECRET secrets).
Pass --python 3.12 (or set PYTHON_VERSIONS) to restrict the matrix, or append a custom command after --, for example scripts/test-in-docker.sh -- pytest -k smartcdn.
To exercise the optional end-to-end upload against a real Transloadit account, provide TRANSLOADIT_KEY and TRANSLOADIT_SECRET (via environment variables or .env) and set PYTHON_SDK_E2E=1:
PYTHON_SDK_E2E=1 scripts/test-in-docker.sh --python 3.12 -- pytest tests/test_e2e_upload.py
The test uploads chameleon.jpg, resizes it, and asserts on the live assembly results.
If you have a global installation of poetry, you can run the tests with:
poetry run pytest --cov=transloadit tests
If you can't use a global installation of poetry, e.g. when using Nix Home Manager, you can create a Python virtual environment and install Poetry there:
python -m venv .venv && source .venv/bin/activate && pip install poetry && poetry install
Then to run the tests:
source .venv/bin/activate && poetry run pytest --cov=transloadit tests
Generate a coverage report with:
poetry run pytest --cov=transloadit --cov-report=html tests
Then view the coverage report locally by opening htmlcov/index.html in your browser.
Contributing
See CONTRIBUTING.md for local development, testing, and release instructions.
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 pytransloadit-1.0.3.tar.gz.
File metadata
- Download URL: pytransloadit-1.0.3.tar.gz
- Upload date:
- Size: 10.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.12 Linux/6.17.5-arch1-1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5a80d0f9191a40fc30f1a52bba9461f34f8495ec8dc48cf9cc92acfacff70935
|
|
| MD5 |
cfc2e06a19c2e723096d400bfb34562d
|
|
| BLAKE2b-256 |
bc5140353b96045f093b6e5d72400338b8bbd4c81e78118e7e65f654c0b2c7fc
|
File details
Details for the file pytransloadit-1.0.3-py3-none-any.whl.
File metadata
- Download URL: pytransloadit-1.0.3-py3-none-any.whl
- Upload date:
- Size: 11.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.12.12 Linux/6.17.5-arch1-1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc8572f413d9bf8959916acddf2f9e59337625f42f0194e499cdeb450e7a30bc
|
|
| MD5 |
aa455faf9f6a0a8e9aca119614e4a6a6
|
|
| BLAKE2b-256 |
b0f6e7e66df914e26be6e07bfd89a92f883a921dbe491777884dc0337f3b8f38
|