gradio常用组件

gradio常用组件

1.gradio程序启动

shell 复制代码
import gradio as gr
def tab():
    pass
with gr.Blocks() as ui:
    gr.Markdown("# <center>🕵️‍♂️gradio test 🕵️‍♂️</center>")
    tab()
ui.launch(server_name='127.0.0.1', server_port=8080,show_api=False, debug=True,share=True)

2.写入html相关代码

shell 复制代码
gr.Markdown("# <center>🕵️‍♂️ Chatglm robot  🕵️‍♂️</center>")

3.文本框

shell 复制代码
# placeholder:默认提示词
text=gr.Textbox( label='user',placeholder='input question')

4. 回车触发事件

shell 复制代码
msg = gr.Textbox( label='user',placeholder='input question')
msg.submit(user, [msg, chatbot], [msg, chatbot], queue=False).then(bot, chatbot, chatbot)

5.选择按钮框

shell 复制代码
mode_name= gr.Radio(['小红', '小白', '小胖', '小黑'], label='name', value='小红')

6.下拉框

shell 复制代码
# value:默认值
# label:组件名称
mode_type= gr.Dropdown(['1','2','3','4'], label='type', value='1')

7.点击按钮

shell 复制代码
# inputs:输入组件(输入参数),outputs:输出组件(输出参数)
# fn:触发时调用的函数
button = gr.Button("点击")
button.click(fn=update_keys, inputs=[model_key], outputs=prompt_key)

8.清空按钮

shell 复制代码
text=gr.Textbox( label='user',placeholder='input question')
clear = gr.Button("清除历史记录")
clear.click(lambda: None, None, text, queue=False)

9.监听组件

  • 输入组件变化,输出组件也变化

    shell 复制代码
    import gradio as gr
    def tab():
        mode_input=gr.Textbox( label='user',placeholder='input question')
        mode_output =gr.Textbox( label='user',placeholder='input question')
        # mode_input值改变,mode_output值也会跟着改变
        # inputs:输入组件(输入参数),outputs:输出组件(输出参数)
        # fn:触发时调用的函数
        mode_input.change(fn=lambda x:x, inputs=mode_input, outputs=mode_output)
    with gr.Blocks() as ui:
        gr.Markdown("# <center>🕵️‍♂️gradio test 🕵️‍♂️</center>")
        tab()
    ui.launch(server_name='127.0.0.1', server_port=8080,show_api=False, debug=True,share=True)
  • 输入组件变化,对应的下拉框显示的值也变化

    shell 复制代码
    # data为pandas文件
    mode_type= gr.Dropdown(types, label='type', value=types[0])
    mode_title = gr.Dropdown(list(data[data['type']==types[0]]['title'].unique()), label='title')
    mode_type.change(fn=lambda x:gr.update(choices=list(data[data['type']==x]['title'].unique())), inputs=mode_type, outputs=mode_title)

10.输出流

shell 复制代码
import time
import gradio as gr

def user(user_message, history):
    return "", history + [[user_message, None]]

def bot(history):
    bot_message = history[-1][0]
    history[-1][1] = ""
    for character in bot_message:
        history[-1][1] += character
        time.sleep(0.05)
        yield history
def robot_tab():
    chatbot = gr.Chatbot(label='robot')
    msg = gr.Textbox( label='user',placeholder='input question')
	  button = gr.Button("generate answer")
   # then: 监听事件
    button.click(user, [msg, chatbot], [msg, chatbot], queue=False).then(bot, chatbot, chatbot)
    clear = gr.Button("清除历史记录")
    clear.click(lambda: None, None, chatbot, queue=False)

with gr.Blocks() as ui:
    gr.Markdown("# <center>🕵️‍♂️ stream  🕵️‍♂️</center>")
    robot_tab()
# 使用队列提交数据
ui.queue()
ui.launch(server_name='127.0.0.1', server_port=8080,show_api=False, debug=True,share=True)

11.template

  • 模板:下代码在这个模板的基础下修改即可

    shell 复制代码
    import cv2
    import gradio as gr
    
    
    def update(mode_name,mode_age,mode_gender,mode_height):
        # image = image.convert('RGB')
        text=f'我叫{mode_name},性别{mode_gender},身高{mode_height},今年{mode_age}岁。'
        return text
        # return image
    
    def prompt_tab():
        with gr.Column():
            with gr.Row():
                image = gr.Image(type='pil', label="Image")
                with gr.Column():
                    mode_name= gr.Radio(['小红', '小白', '小胖', '小黑'], label='name', value='小红')
                    mode_age = gr.Radio(['18', '30', '40', '50'], label='age', value='18')
                    mode_gender = gr.Radio(['女', '男'], label='gender', value='女')
                    mode_height = gr.Dropdown(['160','165','170','175','180'], value='160', label='height')
            prompt = gr.Textbox(label="Prompt")
        button = gr.Button("Personal Information")
        button.click(fn=update, inputs=[mode_name,mode_age,mode_gender,mode_height], outputs=prompt)
    
    
    def image_analysis(input_image):
        output_image =input_image
        return output_image
    
    def analyze_tab():
        with gr.Column():
            with gr.Row():
                # 创建输入组件
                input_image = gr.Image(type='numpy', label="Image")
                with gr.Column():
                    # 创建输出组件
                    # output_image = gr.outputs.Image(type='pil', label="Image")
                    output_image = gr.outputs.Image(type='numpy',label="Image")
        button = gr.Button("Analyze")
        button.click(image_analysis, inputs=[input_image], outputs=[output_image])
    
    with gr.Blocks() as ui:
        gr.Markdown("# <center>🕵️‍♂️ gradio project  🕵️‍♂️</center>")
        with gr.Tab("Prompt"):
            prompt_tab()
        with gr.Tab("Analyze"):
            analyze_tab()
    
    ui.launch(server_name='127.0.0.1', server_port=8080,show_api=False, debug=True,share=True)
相关推荐
蜡笔小炘21 小时前
Mysql 结课项目报告
数据库·adb
Yue丶越21 小时前
【C语言】自定义类型:结构体
c语言·开发语言
合作小小程序员小小店21 小时前
桌面开发,点餐管理系统开发,基于C#,winform,sql server数据库
开发语言·数据库·sql·microsoft·c#
一 乐21 小时前
购物|明星周边商城|基于springboot的明星周边商城系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·spring
科普瑞传感仪器21 小时前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
笃行客从不躺平21 小时前
线程池监控是什么
java·开发语言
星轨初途21 小时前
C++的输入输出(上)(算法竞赛类)
开发语言·c++·经验分享·笔记·算法
m***923821 小时前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存
y1y1z21 小时前
Spring框架教程
java·后端·spring
曾经的三心草21 小时前
基于正倒排索引的Java文档搜索引擎3-实现Index类-实现搜索模块-实现DocSearcher类
java·python·搜索引擎