Python?Streamlit實(shí)現(xiàn)文件的上傳和下載功能
在Web
應(yīng)用中,文件的上傳下載是交互中不可缺少的功能。
因?yàn)樵跇I(yè)務(wù)功能中,一般不會(huì)只有文字的交互,資料或圖片的獲取和分發(fā)是很常見的需求。
比如,文件上傳可讓用戶向服務(wù)器提交數(shù)據(jù),如上傳圖片分享生活、提交文檔用于工作協(xié)作等,豐富應(yīng)用功能。
而文件下載則使用戶能獲取服務(wù)器端的資源,像下載軟件、報(bào)告等,提升用戶對(duì)應(yīng)用內(nèi)容的獲取能力,增強(qiáng)用戶體驗(yàn)和應(yīng)用實(shí)用性。
本篇介紹如何在Streamlit
應(yīng)用中實(shí)現(xiàn)文件的上傳和下載功能。
1. 上傳 st.file_uploader
Streamlit
通過st.file_uploader
可以很方便的實(shí)現(xiàn)文件上傳功能。
st.file_uploader
實(shí)現(xiàn)文件上傳時(shí),包括以下的功能:
- 本地文件選擇:創(chuàng)建一個(gè)文件上傳組件,然后用戶可通過該組件選擇本地文件進(jìn)行上傳
- 限制文件類型:可以指定允許上傳的文件擴(kuò)展名
- 支持多文件上傳:能夠同時(shí)選擇并上傳多個(gè)文件
它的主要參數(shù)有:
名稱 | 類型 | 說明 |
---|---|---|
label | str | 解釋文件上傳用途的簡短標(biāo)簽 |
type | [str] | 允許上傳的文件擴(kuò)展名數(shù)組 |
accept_multiple_files | bool | 是否允許同時(shí)上傳多個(gè)文件 |
key | str | 組件的唯一標(biāo)識(shí) |
help | str | 上傳文件的提示信息 |
on_change | func | 文件上傳時(shí)的回調(diào)函數(shù) |
args | tuple | 傳遞給回調(diào)函數(shù)的可選參數(shù)元組 |
kwargs | dict | 傳遞給回調(diào)函數(shù)的可選參數(shù)字典 |
label_visibility | str | 標(biāo)簽的可見性 |
注意,label_visibility
參數(shù)是配合label
一起使用的,label_visibility
只有3種值:
visible
:這是默認(rèn)值,表示正常顯示label
hidden
:顯示空占位符collapsed
:不顯示標(biāo)簽或占位符
label
參數(shù)也支持一些markdown
格式,可以讓標(biāo)簽內(nèi)容顯示的更加豐富。
下面通過一些示例來演示上傳的使用方法:
1.1. 基本使用
在這個(gè)示例中,st.file_uploader
函數(shù)創(chuàng)建了一個(gè)文件上傳組件,標(biāo)簽為 “選擇文件”。
當(dāng)用戶選擇并上傳文件后,應(yīng)用程序會(huì)顯示上傳文件的文件名。
import streamlit as st uploaded_file = st.file_uploader("選擇文件:") if uploaded_file is not None: st.write(uploaded_file.name)
1.2. 上傳限制
默認(rèn)情況下,Streamlit
允許上傳的文件大小限制為 200MB
。
如果需要修改這個(gè)限制,可以通過配置server.maxUploadSize
選項(xiàng)來實(shí)現(xiàn)。
例如,要將上傳文件大小限制設(shè)置為 500MB
,可以在Streamlit
的配置文件config.toml
文件中添加以下配置:
[server] maxUploadSize = 500
1.3. 允許的文件類型
通過type
參數(shù)指定允許上傳的文件類型。
例如,只允許上傳圖片文件(png
和 jpg
格式),可以這樣使用:
import streamlit as st uploaded_file = st.file_uploader("選擇圖片文件", type=["png", "jpg"])
1.4. 上傳多個(gè)文件
如果需要允許用戶上傳多個(gè)文件,可以將accept_multiple_files
參數(shù)設(shè)置為True
。
示例如下:
import streamlit as st uploaded_files = st.file_uploader("選擇多個(gè)文件:", accept_multiple_files=True) for uploaded_file in uploaded_files: st.write(uploaded_file.name)
1.5. 文件上傳后的回調(diào)
上傳文件后,可以對(duì)文件進(jìn)行各種處理。
例如,可以讀取文件內(nèi)容、將文件保存到本地、使用文件數(shù)據(jù)進(jìn)行計(jì)算等。
以下是一個(gè)讀取上傳的 CSV
文件并顯示數(shù)據(jù)的示例:
import streamlit as st import pandas as pd uploaded_file = st.file_uploader("選擇 CSV 文件:") if uploaded_file is not None: dataframe = pd.read_csv(uploaded_file) st.write(dataframe)
2. 下載 st.download_button
Streamlit
中一般使用st.download_button
來實(shí)現(xiàn)文件下載功能。
當(dāng)用戶點(diǎn)擊下載按鈕時(shí),可以將指定的文件內(nèi)容下載到本地設(shè)備。
這一功能在許多場(chǎng)景中都非常實(shí)用,比如讓用戶下載數(shù)據(jù)報(bào)表、圖片、文檔等。
st.download_button
的主要參數(shù)有:
名稱 | 類型 | 說明 |
---|---|---|
label | str | 解釋文件下載用途的簡短標(biāo)簽 |
data | str / bytes / file | 要下載文件的內(nèi)容 |
file_name | str | 指定下載文件的名稱,若未指定則自動(dòng)生成 |
mime | str | 數(shù)據(jù)的 MIME 類型 |
key | str | 組件的唯一標(biāo)識(shí) |
help | str | 下載文件的提示信息 |
on_click | func | 按鈕點(diǎn)擊時(shí)的回調(diào)函數(shù) |
args | tuple | 傳遞給回調(diào)函數(shù)的可選參數(shù)元組 |
kwargs | dict | 傳遞給回調(diào)函數(shù)的可選參數(shù)字典 |
type | str | 指定按鈕類型 |
icon | str | 按鈕標(biāo)簽旁顯示的表情符號(hào)或圖標(biāo) |
注意,type
參數(shù)只有3種類型:
primary
:背景為應(yīng)用主色強(qiáng)調(diào)secondary
:與背景協(xié)調(diào)tertiary
:無框無背景純文本
下面通過一些示例來演示下載的使用方法:
2.1. 基本使用
下面是一個(gè)簡單的示例,展示如何使用st.download_button
下載一個(gè)字符串內(nèi)容的文件。
import streamlit as st text_contents = "這是一段用來下載的文字。" st.download_button("下載文本文件:", text_contents)
2.2. 下載 CSV 文件
這個(gè)示例中,我們先將DataFrame
轉(zhuǎn)換為 CSV
格式的字節(jié)數(shù)據(jù),然后通過st.download_button
提供下載。
import streamlit as st import pandas as pd @st.cache_data def convert_df(df): # 緩存轉(zhuǎn)換結(jié)果,避免每次重新計(jì)算 return df.to_csv() df = pd.DataFrame({"col1": [1, 2, 3], "col2": ["a", "b", "c"]}) csv_data = convert_df(df) st.download_button( label="下載 CSV", data=csv_data, file_name="data.csv", mime="text/csv", )
2.3. 下載圖片文件
這個(gè)示例中,我們打開一個(gè)圖片文件,以二進(jìn)制讀取模式讀取文件內(nèi)容,并將其作為data
參數(shù)傳遞給下載按鈕。
import streamlit as st with open("image.jpg", "rb") as file: btn = st.download_button( label="下載圖片", data=file, file_name="image.jpg", mime="image/jpeg" )
3. 總結(jié)
總的來說,Streamlit
中的st.file_uploader
和st.download_button
組件是實(shí)現(xiàn)文件交互的關(guān)鍵工具。
使用st.file_uploader
時(shí)要注意上傳大小限制,合理設(shè)置標(biāo)簽與鍵值,處理好文件類型及多文件上傳情況。
對(duì)于st.download_button
,需留意內(nèi)存占用,準(zhǔn)確設(shè)置文件內(nèi)容、名稱與MIME類型,考慮按鈕樣式及回調(diào)函數(shù),同時(shí)防止應(yīng)用意外重新運(yùn)行。
到此這篇關(guān)于Python Streamlit實(shí)現(xiàn)文件的上傳和下載功能的文章就介紹到這了,更多相關(guān)Python Streamlit文件上傳下載內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python實(shí)現(xiàn)rsa加密實(shí)例詳解
這篇文章主要介紹了python實(shí)現(xiàn)rsa加密實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07Python爬蟲簡單運(yùn)用爬取代理IP的實(shí)現(xiàn)
這篇文章主要介紹了Python爬蟲簡單運(yùn)用爬取代理IP的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12解決Python 使用h5py加載文件,看不到keys()的問題
今天小編就為大家分享一篇解決Python 使用h5py加載文件,看不到keys()的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-02-02Python實(shí)現(xiàn)聊天機(jī)器人的示例代碼
這篇文章主要介紹了Python實(shí)現(xiàn)聊天機(jī)器人,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07python 使用cx-freeze打包程序的實(shí)現(xiàn)
這篇文章主要介紹了python 使用cx-freeze打包程序的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子
今天小編就為大家分享一篇python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07