赞
踩
参考: interface
最常用的基础模块构成。
import gradio as gr
def image_classifier(inp):
return {'cat': 0.3, 'dog': 0.7}
demo = gr.Interface(fn=image_classifier, inputs="image", outputs="label")
demo.launch()
一些基本参数的解读:
参考:gradio.Interface.launch(···)
import gradio as gr
def reverse(text):
return text[::-1]
demo = gr.Interface(reverse, "text", "text")
demo.launch(share=True, auth=("username", "password"))
参数名 | 数据类型 | 默认值 | 描述 |
---|---|---|---|
inline | bool/None | None | 是否在界面中以内联的方式显示。在Python笔记本中默认为True,其他情况下默认为False。 |
inbrowser | bool | FALSE | 是否自动在默认浏览器的新标签页中打开界面。 |
share | bool/None | None | 是否创建一个公共链接,使演示可以被任何人访问。如果未提供,默认为False,除非在Google Colab中运行。 |
debug | bool | FALSE | 如果为True,在Google Colab中需要打印错误时会阻塞主线程。 |
enable_queue | bool/None | None | 【已弃用】是否启用队列来处理推理请求,用于防止超时。在HuggingFace Spaces中默认为True,在其他情况下默认为False。 |
max_threads | int | 40 | 并行生成的线程的最大数量。默认继承自starlette库(当前为40)。无论队列是否启用,都适用。但如果启用了队列,该参数将增加到至少队列的并发数。 |
auth | Callable/tuple/… | None | 如果提供,需要用户名和密码(或用户名-密码元组的列表)来访问界面。还可以提供一个函数,该函数接受用户名和密码并返回True表示有效登录。 |
auth_message | str/None | None | 如果提供,将在登录页面上显示的HTML消息。 |
prevent_thread_lock | bool | FALSE | 如果为True,界面将在服务器运行时阻塞主线程。 |
show_error | bool | FALSE | 如果为True,在界面中显示任何错误,并将其打印到浏览器的控制台日志中。 |
server_name | str/None | None | 如果设置为"0.0.0.0",可以使应用在本地网络上可访问。可以通过环境变量GRADIO_SERVER_NAME进行设置。如果为None,则使用"127.0.0.1"。 |
server_port | int/None | None | 将在该端口上启动Gradio应用程序(如果可用)。可以通过环境变量GRADIO_SERVER_PORT进行设置。如果为None,则从7860开始搜索可用端口。 |
show_tips | bool | FALSE | 如果为True,将偶尔显示有关Gradio新功能的提示。 |
height | int | 500 | 包含界面的iframe元素的高度(如果inline=True时使用)。 |
width | int/str | “100%” | 包含界面的iframe元素的宽度(如果inline=True时使用)。 |
encrypt | bool/None | None | 【已弃用】。无效果。 |
favicon_path | str/None | None | 如果提供文件的路径(.png、.gif或.ico),将用作Web页面的favicon(网站图标)。 |
ssl_keyfile | str/None | None | 如果提供文件的路径,将用作创建运行在https上的本地服务器的私钥文件。 |
ssl_certfile | str/None | None | 如果提供文件的路径,将用作https的已签名证书。如果提供了ssl_keyfile,需要提供ssl_certfile。 |
ssl_keyfile_password | str/None | None | 如果提供密码,将与https的SSL证书一起使用。 |
ssl_verify | bool | TRUE | 如果为False,则跳过证书验证,允许使用自签名证书。 |
quiet | bool | FALSE | 如果为True,则抑制大部分打印语句。 |
show_api | bool | TRUE | 如果为True,在应用程序的页脚中显示API文档。默认为True。如果启用了队列,则api_open参数的值将决定是否显示API文档,与show_api参数的值无关。 |
file_directories | list[str]/None | None | 【已重命名为allowed_paths】可以访问的文件路径列表。将在将来的版本中删除。 |
allowed_paths | list[str]/None | None | 允许Gradio访问的完整文件路径或父目录列表(除了包含Gradio Python文件的目录)。必须是绝对路径。警告:如果提供目录,则这些目录及其子目录中的所有文件都可供应用程序的所有用户访问。 |
blocked_paths | list[str]/None | None | 不允许Gradio访问的完整文件路径或父目录列表(即应用程序的用户不允许访问的路径)。必须是绝对路径。警告:优先于allowed_paths和Gradio默认公开的所有其他目录。 |
root_path | str | “” | 应用程序的根路径(或"mount point"),如果应用程序不是从域的根目录(“/”)提供的。通常在应用程序位于转发请求的反向代理后面时使用。例如,如果应用程序在"https://example.com/myapp"提供,则root_path应设置为"/myapp"。LinkTo |
app_kwargs | dict[str, Any]/None | None | 作为参数键和参数值的字典,将附加给底层的FastAPI应用程序。例如,{“docs_url”: “/docs”}。 |
Gradio入门到进阶全网最详细教程[二]:快速搭建AI算法可视化部署演示(侧重参数详解和案例实践)
import gradio as gr from transformers import * title = "抽取式问答" description = "输入上下文与问题后,点击submit按钮,可从上下文中抽取出答案,赶快试试吧!" examples = [ ["普希金从那里学习人民的语言,吸取了许多有益的养料,这一切对普希金后来的创作产生了很大的影响。这两年里,普希金创作了不少优秀的作品,如《囚徒》、《致大海》、《致凯恩》和《假如生活欺骗了你》等几十首抒情诗,叙事诗《努林伯爵》,历史剧《鲍里斯·戈都诺夫》,以及《叶甫盖尼·奥涅金》前六章。", "著名诗歌《假如生活欺骗了你》的作者是"], ["普希金从那里学习人民的语言,吸取了许多有益的养料,这一切对普希金后来的创作产生了很大的影响。这两年里,普希金创作了不少优秀的作品,如《囚徒》、《致大海》、《致凯恩》和《假如生活欺骗了你》等几十首抒情诗,叙事诗《努林伯爵》,历史剧《鲍里斯·戈都诺夫》,以及《叶甫盖尼·奥涅金》前六章。", "普希金创作的叙事诗叫什么"] ] article = "感兴趣的小伙伴可以阅读[Transformers实用指南](https://zhuanlan.zhihu.com/p/548336726)" #预测函数 qa = pipeline("question-answering", model="uer/roberta-base-chinese-extractive-qa") def custom_predict(context, question): answer_result = qa(context=context, question=question) answer = question + ": " + answer_result["answer"] score = answer_result["score"] return answer, score #清除输入输出 def clear_input(): return "", "", "", "" #构建Blocks上下文 with gr.Blocks() as demo: gr.Markdown("# 抽取式问答") gr.Markdown("输入上下文与问题后,点击submit按钮,可从上下文中抽取出答案,赶快试试吧!") with gr.Column(): # 列排列 context = gr.Textbox(label="context") question = gr.Textbox(label="question") with gr.Row(): # 行排列 clear = gr.Button("clear") submit = gr.Button("submit") with gr.Column(): # 列排列 answer = gr.Textbox(label="answer") score = gr.Label(label="score") #绑定submit点击函数 submit.click(fn=custom_predict, inputs=[context, question], outputs=[answer, score]) # 绑定clear点击函数 clear.click(fn=clear_input, inputs=[], outputs=[context, question, answer, score]) gr.Examples(examples, inputs=[context, question]) gr.Markdown("感兴趣的小伙伴可以阅读[Transformers实用指南](https://zhuanlan.zhihu.com/p/548336726)") demo.launch()
其中,
with gr.Column():
是按照顺序的,依次是列排列、行排列、列排列;Button
,需要定义按钮的输入输出,也就是通过 submit.click()
来进行定义,其中submit
定义过程中的input与output,严格遵从对应函数的输入与输出;最终呈现的页面结构是:
几个比较核心的组件,参考【定制你的Blocks UI布局:Gradio的Block Layouts模块介绍】
Row是Blocks模块中的一个布局元素,它将所有子组件水平排列。
参数:
Column是Blocks模块中的一个布局元素,它将所有子组件垂直排列。可以通过scale和min_width参数设置列的宽度。
参数:
Tab(或其别名TabItem)是Blocks模块中的一个布局元素,组件定义在选中的标签页中可见。
参数:
Accordion是Blocks模块中的一个布局元素,可以切换显示/隐藏所包含的内容。
参数:
change方法用于在组件的值发生变化时触发事件,无论是因为用户输入(例如用户在文本框中输入)还是函数更新(例如图像从事件触发的输出接收到值)。该方法适用于Gradio Blocks中的组件。
参数说明:
来看一个案例:
import gradio as gr def change_textbox(choice): if choice == "short": return gr.Textbox(lines=2, visible=True) elif choice == "long": return gr.Textbox(lines=8, visible=True, value="Lorem ipsum dolor sit amet") else: return gr.Textbox(visible=False) with gr.Blocks() as demo: radio = gr.Radio( ["short", "long", "none"], label="What kind of essay would you like to write?" ) text = gr.Textbox(lines=2, interactive=True, show_copy_button=True) radio.change(fn=change_textbox, inputs=radio, outputs=text) demo.launch()
核心的radio.change
,实现了选择不同的选项["short", "long", "none"]
,就会显示不同的gr.Textbox
的信息
第二个案例:
import math import gradio as gr import plotly.express as px import numpy as np plot_end = 2 * math.pi def get_plot(period=1): global plot_end x = np.arange(plot_end - 2 * math.pi, plot_end, 0.02) y = np.sin(2*math.pi*period * x) fig = px.line(x=x, y=y) plot_end += 2 * math.pi if plot_end > 1000: plot_end = 2 * math.pi return fig with gr.Blocks() as demo: with gr.Row(): with gr.Column(): gr.Markdown("Change the value of the slider to automatically update the plot") period = gr.Slider(label="Period of plot", value=1, minimum=0, maximum=10, step=1) plot = gr.Plot(label="Plot (updates every half second)") dep = demo.load(get_plot, None, plot, every=1) period.change(get_plot, period, plot, every=1, cancels=[dep]) if __name__ == "__main__": demo.queue().launch()
架构为:
具体参数可参考:探索Gradio库中的Textbox模块及其强大功能
Gradio的Textbox模块允许用户输入字符串并显示字符串输出。它创建一个文本区域,用户可以在其中输入文本或显示输出结果。
Textbox模块的初始化参数包括value、lines、max_lines、placeholder、label、info、every、show_label、container、scale、min_width、interactive、visible、elem_id、elem_classes、type和show_copy_button等。这些参数可以根据需要进行配置,以满足不同的应用场景和需求。
Textbox模块提供了多个事件监听方法,包括change、input、submit、select和blur。这些方法可以用于在用户与组件进行交互时执行相应的操作。
具体参数:
Button组件是Gradio中的一个模块,用于创建一个按钮,并可以为其分配任意的click()事件。按钮的标签(value)可以作为输入使用,或者通过函数的输出来设置。
按钮的参数和方法如下:
click方法用于添加一个监听器,当组件(如按钮)被点击时触发。方法的参数如下:
Checkbox模块的参数及其功能:
Checkbox模块除了具有上述参数之外,还提供了change、input和select方法用于事件监听和处理
参考:
使用gradio库的File模块实现文件上传和展示
File模块是gradio库中的一个组件,用于创建一个文件组件,允许用户上传通用文件(用作输入)或显示通用文件(用作输出)。
File模块参数:
file常用的方法:
参考:探索Gradio的Chatbot模块:创建交互式聊天机器人
chatbot模块是Gradio中的一个组件,用于展示聊天机器人的输出,包括用户提交的消息和机器人的回复。它支持一些Markdown语法,包括粗体、斜体、代码和图片等。Chatbot模块的输入不接受用户输入,而是通过函数返回的列表来设置聊天内容。返回的列表应包含多个内部列表,每个内部列表包含两个元素:用户消息和机器人回复。消息可以是字符串、元组或None。如果消息是字符串,可以包含Markdown格式的文本。如果消息是元组,应包含文件路径和可选的替代文本。值为None的消息将不会显示在聊天界面上。
下面是一些常用的参数:
一些实践案例(参考:使用Gradio创建一个chatbot机器人):
import gradio as gr import random import time with gr.Blocks() as demo: chatbot = gr.Chatbot() msg = gr.Textbox() clear = gr.Button("清除") def respond(message, chat_history): bot_message = random.choice(["你好吗?", "我爱你", "我很饿"]) chat_history.append((message, bot_message)) time.sleep(1) return "", chat_history msg.submit(respond, [msg, chatbot], [msg, chatbot]) clear.click(lambda: None, None, chatbot, queue=False) demo.launch()
其中,chatbot可以作为输入项,在respond
函数中是聊天历史信息,其中chatbot()
接收的可以是[['testtt ', '我爱你'], ('11111', '我爱你')]
元组集合。
另外,清除按钮clear.click
可以lambda: None
直接清除信息
import gradio as gr import random import time with gr.Blocks() as demo: chatbot = gr.Chatbot() msg = gr.Textbox() clear = gr.Button("清除") def user(user_message, history): return "", history + [[user_message, None]] def bot(history): bot_message = random.choice(["你好吗?", "我爱你", "我很饿"]) history[-1][1] = "" for character in bot_message: history[-1][1] += character time.sleep(0.05) yield history msg.submit(user, [msg, chatbot], [msg, chatbot], queue=False).then( bot, chatbot, chatbot ) clear.click(lambda: None, None, chatbot, queue=False) demo.queue() demo.launch()
流式处理这里使用.then()
方法链接了两个事件user
+ bot
, yield
来进行流式化;
另外,历史数据同样可以通过chatbot还回传,就是这句了:history + [[user_message, None]]
其中,
我们通过运行demo.queue()启用排队,这是流式输出所需的.
当然,这里其实还可以使用一些色彩填充的方式,让chatbot的对话框好看:
chatbot = gr.Chatbot().style(color_map=("green", "pink"))
在首次打开网页前,可以设置账户密码。比如auth参数为(账户,密码)的元组数据。这种模式下不能够使用queue函数。
demo.launch(auth=("admin", "pass1234"))
如果想设置更为复杂的账户密码和密码提示,可以通过函数设置校验规则。
#账户和密码相同就可以通过
def same_auth(username, password):
return username == password
demo.launch(auth=same_auth,auth_message="username and password must be the same")
参考:Gradio入门到进阶全网最详细教程[二]:快速搭建AI算法可视化部署演示(侧重参数详解和案例实践)
import gradio as gr from transformers import * #标题 title = "抽取式问答" #题下的描述,支持md格式 description = "输入上下文与问题后,点击submit按钮,可从上下文中抽取出答案,赶快试试吧!" #输入样例 examples = [ ["普希金从那里学习人民的语言,吸取了许多有益的养料,这一切对普希金后来的创作产生了很大的影响。这两年里,普希金创作了不少优秀的作品,如《囚徒》、《致大海》、《致凯恩》和《假如生活欺骗了你》等几十首抒情诗,叙事诗《努林伯爵》,历史剧《鲍里斯·戈都诺夫》,以及《叶甫盖尼·奥涅金》前六章。", "著名诗歌《假如生活欺骗了你》的作者是"], ["普希金从那里学习人民的语言,吸取了许多有益的养料,这一切对普希金后来的创作产生了很大的影响。这两年里,普希金创作了不少优秀的作品,如《囚徒》、《致大海》、《致凯恩》和《假如生活欺骗了你》等几十首抒情诗,叙事诗《努林伯爵》,历史剧《鲍里斯·戈都诺夫》,以及《叶甫盖尼·奥涅金》前六章。", "普希金创作的叙事诗叫什么"] ] #页面最后的信息,可以选择引用文章,支持md格式 article = "感兴趣的小伙伴可以阅读[gradio专栏](https://blog.csdn.net/sinat_39620217/category_12298724.html?spm=1001.2014.3001.5482)" qa = pipeline("question-answering", model="uer/roberta-base-chinese-extractive-qa") def custom_predict(context, question): answer_result = qa(context=context, question=question) answer = question + ": " + answer_result["answer"] score = answer_result["score"] return answer, score gr.Interface(fn=custom_predict, inputs=["text", "text"], outputs=[gr.Textbox(label="answer"), gr.Label(label="score")], title=title, description=description, examples=examples, article=article).launch()
运行上述代码,将看到如下页面,这里的example是可以点击的,点击后将自动填充至context和question中
由于description和article字段支持md语法,因此我们可以根据需求,自行的去丰富完善各部分内容
注意点:
text
文本框,outputs也是两个框,一个是gr.Textbox(label="answer")
名为answer
的框,另一个是gr.Label(label="score")
是名为score
的数值型内容def custom_predict(context, question):
这个函数当中的context
和 question
的命名会影响到下面框框左上角的命名比较简单的示范代码,参考:利用Gradio的UploadButton模块实现文件上传功能
import gradio as gr
def upload_file(files):
file_paths = [file.name for file in files]
return file_paths
with gr.Blocks() as demo:
file_output = gr.File()
upload_button = gr.UploadButton("Click to Upload a File", file_types=["image", "video"], file_count="multiple")
upload_button.upload(upload_file, upload_button, file_output)
demo.launch()
其中gr.File()
执行就代表已经把文件进行保存到临时文件夹中,临时文件夹并不是自己指定的,所以如果要指定某一个文件夹,可以看一下之后的一个例子;
主函数upload_file
,输入是gr.File()
,输出是文件名称
另外改编:
使用gradio库的File模块实现文件上传和生成可下载文件
import os import gradio as gr import tempfile import shutil def generate_file(file_obj): # global tmpdir print('临时文件夹地址:{}'.format('tmpdir')) print('上传文件的地址:{}'.format(file_obj.name)) # 输出上传后的文件在gradio中保存的绝对地址 #获取到上传后的文件的绝对路径后,其余的操作就和平常一致了 # 将文件复制到临时目录中 shutil.copy(file_obj.name, 'tmpdir') # 获取上传Gradio的文件名称 FileName=os.path.basename(file_obj.name) # 获取拷贝在临时目录的新的文件地址 NewfilePath=os.path.join('tmpdir',FileName) print(NewfilePath) # 打开复制到新路径后的文件 with open(NewfilePath, 'rb') as file_obj: #在本地电脑打开一个新的文件,并且将上传文件内容写入到新文件 outputPath=os.path.join('tmpdir',FileName) with open(outputPath,'wb') as w: w.write(file_obj.read()) # 返回新文件的的地址(注意这里) return outputPath inputs = gr.components.File(label="上传文件") outputs = gr.components.File(label="下载文件") # 创建 Gradio 应用程序g app = gr.Interface(fn=generate_file, inputs=inputs, outputs=outputs, title="文件上传、并生成可下载文件demo", description="上传任何文件都可以,只要大小别超过你电脑的内存即可" ) # 启动应用程序 app.launch(share=True)
文件存在tmpdir
文件夹;最后呈现的效果是:左上传、右下载
参考文献:
Gradio入门到进阶全网最详细教程[一]:快速搭建AI算法可视化部署演示(侧重项目搭建和案例分享)
Gradio入门到进阶全网最详细教程[二]:快速搭建AI算法可视化部署演示(侧重参数详解和案例实践)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。