gradio学习代码部分

复制代码
import gradio as gr
# 创建 Block 界面(更灵活的界面布局)
with gr.Blocks() as demo:
    # 标题(可选,让界面更好看)
    gr.Markdown("# 最简单的 Gradio 输入框")
    # 文本输入框
    gr.Textbox(label="输入框", placeholder="请输入内容")
# 启动 Web 界面
if __name__ == '__main__':
    demo.launch()
复制代码
#gr.Button => 创建一个按钮,可以用于绑定点击事件
import gradio as gr
# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    # 创建一个按钮
    gr.Button("提交")
if __name__ == '__main__':
    demo.launch()
复制代码
# gr.slider => 创建一个滑块
# 属性:
# minimum => 最小值
# maximum => 最大值
# value => 默认值
# label => 选择数值
import gradio as gr
def update_output(value):
    return f"您选择的数值是:{value}"
# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    # 创建一个滑块
    slider = gr.Slider(minimum=0, maximum=100, value=50, label="选择数值")
# 创建输出文本框
    output = gr.Textbox(label="结果")
    # 绑定滑块变化事件
    slider.change(update_output, inputs=slider, outputs=output)
if __name__ == '__main__':
    demo.launch()
复制代码
#下拉框
import gradio as gr

# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    dropdown = gr.Dropdown(choices=["选项1", "选项2", "选项3"], label="选择选项")
    output = gr.Textbox(label="结果")
    dropdown.change(lambda x: f"您选择的选项是:{x}", inputs=dropdown, outputs=output)
if __name__ == '__main__':
    demo.launch()
复制代码
#文件上传
import gradio as gr

# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    gr.File(label="上传文件",file_types=["image", "video", "audio", "text", "pdf"])
    
if __name__ == '__main__':
    demo.launch()
复制代码
#gradio聊天机器人
import gradio as gr

# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    gr.Chatbot(label="聊天机器人")
    gr.Textbox(label="输入")
    gr.Button("提交")
    gr.Button("清空")

if __name__ == '__main__':
    demo.launch()
复制代码
#row column
import gradio as gr

# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    with gr.Row():
        # 左边的列,占4成的比例
        with gr.Column(scale=4):
            gr.Textbox(label="左边的输入框")
        
        # 右边的列,占1成比例  
        with gr.Column(scale=1):
            gr.Slider(minimum=0, maximum=100, value=50, label='右边滑块')

if __name__ == '__main__':
    demo.launch()
复制代码
#click事件
import gradio as gr
def onbutton_output(value):
    return f"您点击的数值是:{value}"
with gr.Blocks() as demo:
    # 创建一个文本框,用于接受用户的输入
    input_text = gr.Textbox(label="输入")
    # 创建按钮
    submit_button = gr.Button("提交")
    # 创建一个文本框,用于显示结果
    output_text = gr.Textbox(label="输出")
    # 事件 => 点击事件 => click
    submit_button.click(fn=onbutton_output, inputs=input_text, outputs=output_text)
if __name__ == '__main__':
    demo.launch()
复制代码
#change事件
import gradio as gr
# 创建Gradio Blocks应用
with gr.Blocks() as demo:
    dropdown = gr.Dropdown(choices=["选项1", "选项2", "选项3"], label="选择选项")
    output = gr.Textbox(label="结果")
    dropdown.change(lambda x: f"您选择的选项是:{x}", inputs=dropdown, outputs=output)
if __name__ == '__main__':
    demo.launch()
复制代码
#练习1
def greet(name, age):
    return f"你好,{name},你今年{age}岁了"

with gr.Blocks() as demo:
    # 创建一行,用于放置输入的组件
    with gr.Row():
        # 姓名的文本框
        name_input = gr.Textbox(label="请输入您的名字")
        # 
        age_input = gr.Slider(minimum=0, maximum=100, label="请选择您的年龄", interactive=True)
        # 创建一个按钮,用于触发事件
        submit_button = gr.Button("提交")
        outputs=gr.Textbox(label="输出")
        submit_button.click(fn=greet, inputs=[name_input, age_input], outputs=outputs)

if  __name__ == '__main__':
    demo.launch()
复制代码
#练习2
import gradio as gr

# 定义一个水果的列表
fruit_choices = ["🍎", "🍊", "🍇", "🍌"]

# 编写函数
def display_choice(select_fruit):
    return f"您选择的水果是 => {select_fruit}"

with gr.Blocks() as demo:
    # 添加一个标题 => HTML标签
    gr.HTML("<h1 align='center'>请选择您的水果</h1>")
    
    # 创建一个行布局
    with gr.Row():
        # 创建一个下拉框,提供让用户进行选择
        fruit_dropdown = gr.Dropdown(
            choices = fruit_choices,
            label = "请选择一种水果",
            interactive = True,
            value = fruit_choices[2]
        )
    
    # 创建文本框,用于用户选择的水果的显示
    output = gr.Textbox(label = "您选择的水果是")
    
    # 编写函数的绑定
    fruit_dropdown.change(fn = display_choice, inputs = fruit_dropdown, outputs = output)

if __name__ == "__main__":
    demo.launch()
复制代码
import gradio as gr

def response(message, chat_history):
    if message.strip():
        bot_response = f"我已经收到您的消息:'{message}'"
        # 新版格式:添加两个字典,分别代表用户和助手的消息
        chat_history.append({"role": "u。ser", "content": message})
        chat_history.append({"role": "assistant", "content": bot_response})
    return chat_history, ""

with gr.Blocks() as demo:
    gr.HTML("<h1 align='center'>欢迎使用聊天机器人</h1>")
    
    chatbot = gr.Chatbot(
        show_label=False, 
        height=400,
        placeholder="聊天记录将显示在这里..."
    )
    
    with gr.Row():
        user_input = gr.Textbox(
            placeholder="请在这里输入您的消息...", 
            show_label=False,
            scale=4,
            lines=2
        )
        submit_button = gr.Button("提交", scale=1)
    
    submit_button.click(
        fn=response,
        inputs=[user_input, chatbot],
        outputs=[chatbot, user_input]
    )
    
    user_input.submit(
        fn=response,
        inputs=[user_input, chatbot],
        outputs=[chatbot, user_input]
    )

if __name__ == '__main__':
    demo.launch()
相关推荐
JS菌3 分钟前
手写一个 AI Agent 全栈项目:从沙箱执行到子智能体的完整实现
前端·人工智能·后端
wang090731 分钟前
自己动手写一个spring之IOC_2
java·后端·spring
来杯@Java43 分钟前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
excel1 小时前
HLS TS 文件损坏的元凶:Git 提交与拉取
前端
Aphasia3111 小时前
https连接传输流程
前端·面试
徐小夕1 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
threelab2 小时前
Three.js 物理模拟着色器 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
武器大师722 小时前
lv_binding_js 代码解读
开发语言·javascript·ecmascript
不知名的老吴2 小时前
线程的生命周期之线程“插队“
java·开发语言·python