Introducing Gradio Clients
WatchIntroducing Gradio Clients
WatchNew to Gradio? Start here: Getting Started
See the Release History
gradio.UploadButton(···)
str
or bytes
object, or a list of str
or list of bytes
objects, depending on type
and file_count
.def predict(
value: bytes | str | list[bytes] | list[str] | None
)
...
str
filepath or URL, or a list[str]
of filepaths/URLs.def predict(···) -> str | list[str] | None
...
return value
Class | Interface String Shortcut | Initialization |
---|---|---|
| "uploadbutton" | Uses default values |
from pathlib import Path
import gradio as gr
def upload_file(filepath):
name = Path(filepath).name
return [gr.UploadButton(visible=False), gr.DownloadButton(label=f"Download {name}", value=filepath, visible=True)]
def download_file():
return [gr.UploadButton(visible=True), gr.DownloadButton(visible=False)]
with gr.Blocks() as demo:
gr.Markdown("First upload a file and and then you'll be able download it (but only once!)")
with gr.Row():
u = gr.UploadButton("Upload a file", file_count="single")
d = gr.DownloadButton("Download the file", visible=False)
u.upload(upload_file, u, [u, d])
d.click(download_file, None, [u, d])
if __name__ == "__main__":
demo.launch()
Event listeners allow you to respond to user interactions with the UI components you've defined in a Gradio Blocks app. When a user interacts with an element, such as changing a slider value or uploading an image, a function is called.
The UploadButton component supports the following event listeners. Each event listener takes the same parameters, which are listed in the Event Parameters table below.
Listener | Description |
---|---|
| Triggered when the UploadButton is clicked. |
| This listener is triggered when the user uploads a file into the UploadButton. |