關(guān)于Gradio中Button用法及事件監(jiān)聽器click方法使用
Gradio中Button用法及事件監(jiān)聽器click方法使用
瞎想亂記
事情是這樣的:入職時面試的是Java,簡歷中寫了會python,剛好最近有個小項(xiàng)目需要用Python實(shí)現(xiàn),老板就將這個項(xiàng)目交給了我,我…
項(xiàng)目中還真遇到了好幾個坑,分享一下
功能介紹
功能很簡單,就是一個添加一個按鈕,并給這個按鈕添加一個監(jiān)聽器,實(shí)現(xiàn)click方法(我一個后端搞起了前端,以后請叫我全棧)。
相關(guān)代碼
Gradio的基礎(chǔ)不再介紹了,不會的可以去先看看基礎(chǔ)
按鈕的代碼如下:
import gradio as gr
submit_button = gr.Button('提交')以上是定義了一個名為“提交”的按鈕,我想實(shí)現(xiàn)通過點(diǎn)擊此按鈕實(shí)現(xiàn)某個方法,輸出一行文字,方法的入?yún)⒂腥齻€參數(shù)
具體代碼如下:
image = gr.Image(label="圖片", sources=["upload"], type="filepath") video = gr.Video(label="視頻", sources=["upload"], format='mp4') audio = gr.Audio(label="音頻", sources=["upload"]) output_video = gr.Text() submit_button.click(fun_train_video, inputs=[image, video, audio], outputs=output_video)
稍微解釋下這行代碼,click是按鈕的監(jiān)聽器,當(dāng)點(diǎn)擊“提交”按鈕后,會運(yùn)行函數(shù)fun_train_video,這個函數(shù)的入?yún)⒂腥齻€,
分別是:image,video,audio,函數(shù)的輸出是output_video。
這樣的代碼pycharm并沒有報錯,但是在運(yùn)行時會出下下面的錯誤
“inputs”: [block._id for block in self.inputs],
^^^^^^^^^
AttributeError: ‘tuple’ object has no attribute ‘_id’

解決方法
查了很多資料,包括chatGPT,但是并沒有得到理想的答案,問題遲遲沒有解決,眼看著項(xiàng)目要交付,著急啊,后來想起了我的研究生室友,人稱憨憨,上學(xué)時寫的一手好python,果斷請教,最后得到解決。
其實(shí)這個問題的根源是這樣的:在監(jiān)聽器click方法中,inputs參數(shù)需要傳入一個包含輸入組件的列表,但是inputs=[image, video, audio]這種寫法是包含元組的列表,這個元組包含了輸入組件和它的標(biāo)簽,但不是組件本身。
當(dāng)gradio嘗試獲取輸入組件id的時候,會從元組中獲取_id屬性,但是元組中沒有這個屬性,就會拋出異常。
修改代碼如下
submit_button.click(fun_train_video, inputs=[image[0], video, audio], outputs=output_video)
那就是在第一個參數(shù)后邊加一個序號,這樣gradio就可以找到組件的id了,挺神奇的,更深層的邏輯還有待去了解,問題總算解決了。
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python DNS查詢放大攻擊實(shí)現(xiàn)原理解析
這篇文章主要介紹了Python DNS查詢放大攻擊實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-10-10
小結(jié)Python用fork來創(chuàng)建子進(jìn)程注意事項(xiàng)
今天看到別人的源代碼中有 fork 子進(jìn)程來操作數(shù)據(jù)。但是由于 fork 之后,沒有及時的退出,導(dǎo)致系統(tǒng)中的Python進(jìn)程越來越多,子進(jìn)程越來越多了。2014-07-07
python3 使用traceback定位異常實(shí)例
這篇文章主要介紹了python3 使用traceback定位異常實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
使用Numpy讀取CSV文件,并進(jìn)行行列刪除的操作方法
今天小編就為大家分享一篇使用Numpy讀取CSV文件,并進(jìn)行行列刪除的操作方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
詳解如何利用Python實(shí)現(xiàn)報表自動化
這篇文章主要介紹了報表自動化的流程,并教你用Python實(shí)現(xiàn)工作中的一個報表自動化實(shí)戰(zhàn),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-03-03
小眾實(shí)用的Python 爬蟲庫RoboBrowser
這篇文章主要介紹了Python 爬蟲庫RoboBrowser的使用簡介,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-03-03
scrapy自定義pipeline類實(shí)現(xiàn)將采集數(shù)據(jù)保存到mongodb的方法
這篇文章主要介紹了scrapy自定義pipeline類實(shí)現(xiàn)將采集數(shù)據(jù)保存到mongodb的方法,涉及scrapy采集及操作mongodb數(shù)據(jù)庫的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-04-04

