Streamlit component to download a file programmatically, without user input.
Project description
Streamlit Downloader
A Streamlit component that triggers an automatic download of one or more files without requiring user interaction.
Installation
pip install streamlit-downloader
Usage
Use the downloader function to initiate a download. The component will automatically trigger the browser's download dialog when the page loads or when the component is rendered.
Downloading a Single File
import streamlit as st
from streamlit_downloader import downloader
# The `downloader` function returns True when the download is complete.
st.subheader("Download a single file")
data_to_download = b'Hello, this is the content of the file.'
filename = "my_text_file.txt"
content_type = "text/plain"
if st.button("Start Download"):
download_complete = downloader(
data=data_to_download,
filename=filename,
content_type=content_type
)
if download_complete:
st.success(f"File '{filename}' has been downloaded!")
Downloading Multiple Files
The downloader component can handle multiple files by being called multiple times.
import streamlit as st
from streamlit_downloader import downloader
st.subheader("Download multiple files")
# File 1 details
data_file1 = b"This is the first file."
filename_file1 = "file1.txt"
content_type_file1 = "text/plain"
# File 2 details
data_file2 = b"This is the second file."
filename_file2 = "file2.csv"
content_type_file2 = "text/csv"
if st.button("Download Both Files"):
# The component must be called for each file you want to download.
download_complete_1 = downloader(
data=data_file1,
filename=filename_file1,
content_type=content_type_file1,
)
download_complete_2 = downloader(
data=data_file2,
filename=filename_file2,
content_type=content_type_file2,
)
if download_complete_1 and download_complete_2:
st.success("All files have been downloaded!")
Parameters
The downloader function accepts the following parameters:
data: The raw data of the file to be downloaded. This can be a string, bytes, or a similar data type.filename: The name the downloaded file will have.content_type: The MIME type of the file (e.g.,text/csv,application/pdf).key: (Optional) A unique key for the component, required when you have multiple downloaders on the same page.
How It Works
The component leverages the browser's ability to trigger downloads using a hidden link element. When the Streamlit component is rendered, it uses JavaScript to create a Blob from the data, creates a temporary <a> element, sets its href to a URL created from the Blob, and simulates a click to initiate the download. The component is visually hidden to provide a seamless user experience.
Development
To run the example app and test changes:
- Navigate to the
streamlit_downloaderdirectory. - Run
streamlit run example.py.
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 streamlit_downloader-0.0.2.tar.gz.
File metadata
- Download URL: streamlit_downloader-0.0.2.tar.gz
- Upload date:
- Size: 125.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7c7a5a80fb3e4fde030bb06df4661526d1a3c11b025ca7e8eff8e6b2c0d9b437
|
|
| MD5 |
2461aa704df46bdc7bd75ffa46632ec5
|
|
| BLAKE2b-256 |
29769f7ff5484221b9115ca019a83543a491aaf65a7c186034d9d8828bbf1b08
|
File details
Details for the file streamlit_downloader-0.0.2-py3-none-any.whl.
File metadata
- Download URL: streamlit_downloader-0.0.2-py3-none-any.whl
- Upload date:
- Size: 125.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3df76d87fdaa5013d10def6df6a6a3bac4e30a8662c69840cda0a05b1afbb005
|
|
| MD5 |
b9d4cebe1fa279f5205c1614ef3eb9d2
|
|
| BLAKE2b-256 |
ae00a3641128d1de33475df931af62de15e925c06b941d8a61b7d4755a51de64
|