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()
相关推荐
子兮曰11 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
测试员周周11 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
2401_8734794011 小时前
运营活动被薅羊毛怎么防?用IP查询+设备指纹联动封堵漏洞
java·网络·tcp/ip·github
ShiJiuD66688899911 小时前
大事件板块一
java
摇滚侠11 小时前
@Autowired 和 @Resource 的区别
java·开发语言
SeaTunnel12 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源
西洼工作室12 小时前
前端直传OSS服务端签名(Policy+Signature)/STS临时凭证
前端·文件上传·oss
吴声子夜歌13 小时前
Java——线程的基本协作机制
java·线程协作
你很易烊千玺13 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
谙弆悕博士13 小时前
【附C++源码】从零开始实现 2048 游戏
java·c++·游戏·源码·项目实战·2048