【Python小技巧】使用Gradio 构建基于ChatGPT的AI绘图 Web 应用(附源码)

2023-05-16

文章目录

  • 前言
  • 一、Gradio是什么?
  • 二、使用Gradio构建基于ChatGPT的 Web 应用
    • 1. 安装gradio库
    • 2. 安装openai库(ChatGPT的python库)
    • 3. Web 应用示例(源代码)
  • 总结


前言

都说ChatGPT也可以生成图片,好奇的我也尝试包装了一个方法,在本地就可以通过Python访问openai并将结果展现出来,具体怎么做,请看下文。

一、Gradio是什么?

Gradio是一个开源的 Python 库,用于构建机器学习和数据科学演示和 Web 应用。

官网:https://www.gradio.app/

Gradio适用于:

  • 演示客户/合作者/用户/学生的机器学习模型。
  • 部署通过自动共享链接快速创建模型,并获得模型性能反馈。
  • 排除故障使用内置的操作和解释工具,在开发过程中以交互方式处理您的模型。

案例展示:https://huggingface.co/spaces/hysts/insightface-SCRFD
安装包:https://pypi.org/project/gradio/
Github:https://github.com/gradio-app/gradio

二、使用Gradio构建基于ChatGPT的 Web 应用

1. 安装gradio库

pip install gradio -i https://pypi.tuna.tsinghua.edu.cn/simple

2. 安装openai库(ChatGPT的python库)

pip install openai -i https://pypi.tuna.tsinghua.edu.cn/simple

请提前申请好账号,并生成密钥。

3. Web 应用示例(源代码)

注:openai.api_key 需更换为自己的密钥

import openai
import gradio as gr
from gradio.components import Textbox,Image
openai.api_key = "sk-xxx"  # 更换为自己的密钥


def ChatGPT_AI_DrawBot(input):
    if input:
        response = openai.Image.create(
          prompt=input,
          n=1,
          size="1024x1024"
        )
        image_url = response['data'][0]['url']
        return image_url

inputs = Textbox(lines=7, label="请输入你的问题")
outputs = Image(label="ChatGPT AI结果")

gr.Interface(fn=ChatGPT_AI_DrawBot, inputs=inputs, outputs=outputs, title="ChatGPT AI助理",
             description="我是您的AI助理,输入您的绘图关键字,我将为您进行关键字的AI绘图",
             theme=gr.themes.Default()).launch(share=True)


运行后出现以下提示即为成功。
在这里插入图片描述
按Ctrl并鼠标点击http://127.0.0.1:7860 即可打开浏览器访问该网址。

给ChatGPT写入一段话:

在一片巨大的森林里,数十棵巨大的百年橡树,金色的秋天,浩瀚的晨光,穿过树枝的天空,一棵长着翡翠叶子的石头树,地面上有巨大的水晶和钻石,所有这些都有多种颜色,淡蓝色的雾,金色的部分,细节,真实感,照片

Submit后,ChatGPT运算后会将生成的图片展示在右侧。点击图片右上角即可下载该图片(直接下载会保存为image.txt,修改扩展名为jpg后即可显示为图片)。如下所示:
在这里插入图片描述
最终生成的1024*1024像素图片:

在这里插入图片描述


总结

这里是ChatGPT 3.5引擎生成的图片,仅作一个展示,抛砖引玉。期待大家更好的作品!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【Python小技巧】使用Gradio 构建基于ChatGPT的AI绘图 Web 应用(附源码) 的相关文章

  • iOS 系统自带地图 基本实现

    CLLocationManager 首先 xff0c 来讲一下CLLocationManager 因为 xff0c 有人明天要用到 xff0c 临时写的 那么怎么使用呢 xff1f 首先需要定义一个CLLocationManager的属性
  • norflash和nandflash;SRAM和SDRAM

    一 常见存储类型 典型应用名称描述MCU片内flashnorflash nor flash数据线和地址线分开 xff0c 可以实现ram一样的随机寻址功能 xff0c 可以读取任何一个字节 但是擦除仍要按块 页 擦除 因为按照字节寻址 xf
  • 断言ASSERT使用详解

    一 assert的定义 原以为assert 仅仅是个报错函数 xff0c 事实上 xff0c 它居然是个宏 xff0c 并且作用并非 34 报错 34 在经过对其进行一定了解之后 xff0c 对其作用及用法有了一定的了解 xff0c ass
  • 快速排序qsort函数用法

    一 qsort函数简介 排序方法有很多种 xff1a 选择排序 xff0c 冒泡排序 xff0c 归并排序 xff0c 快速排序等 看名字都知道快速排序是目前公认的一种比较好的排序算法 因为他速度很快 xff0c 所以系统也在库里实现这个算
  • 调度器锁rt_enter_critical() & rt_exit_critical()

    一 函数说明 void rt enter critical void 进入临界区 调用这个函数后 xff0c 调度器将被上锁 在系统锁住调度器的期间 xff0c 系统依然响应中断 xff0c 如果中断唤醒了的更高优先级线程 xff0c 调度
  • RT Thread studio同时生成bin和hex文件

    一 RTT默认生成bin文件 默认选择Raw binary xff0c 则项目对应的debug文件夹下生成bin文件 xff1b 修改成intel的话 xff0c 则项目对应的debug文件夹下生产hex文件 xff1b 二 同时生成bin
  • 使用CJSON 解析JSON 结构体数组【典型】

    1 CJSON数据结构定义 define cJSON False 0 define cJSON True 1 define cJSON NULL 2 define cJSON Number 3 define cJSON String 4 d
  • RTThread:静态线程&动态线程

    一 静态线程创建 rt thread init rt err t rt thread init struct rt thread thread const char name void void parameter entry void p
  • C指针传参的一些思考

    一 仅操作变量名的子函数 xff0c 在主函数中无法真正实现值传递 如下 xff1a void swap 1 int num1 int num2 作为主函数的子函数 xff0c 被main函数调用 xff1b 在子函数内部实现了num1 和
  • 再论指针数组与数组指针

    一 二者的区别 xff08 一 xff09 直观的差异 int p 5 指针数组 xff0c 元素为指针 int p 5 数组指针 xff0c 指向数组的指针 xff08 二 xff09 非直观差异 1 xff09 数组指针 xff1a 待
  • Anaconda Prompt工作路径的切换

    Anaconda Prompt工作路径的切换 缘由进入Anaconda Prompt激活 labelme所在环境退出到现在所在盘的根目录进入目标盘输入目标文件路径 缘由 数据集制作过程中 xff0c 想要进入D盘下的存放json的文件夹 x
  • 认识一下 Azure DevOps

    目录 新手入门 认识 安装入门 Azure Board 敏捷面板Azure Repos 代码仓库Azure Pipeline CI CD 管道Azure Test Plan 测试管理Azure Artifact 包托管 Azure DevO
  • 10个数比大小(排序)——冒泡和选择

    10个数比大小 xff08 排序 冒泡和选择 一 冒泡法 xff08 起泡法 xff09 冒泡排序的基本概念是 以升序排序为例 xff1a 依次比较相邻的两个数 xff0c 将小数放在前面 xff0c 大数放在后面 即在第一趟 xff1a
  • vue3 实现界面数据实时变化

    技术支持 xff1a Vue3 ElementUI WebSocket 库引用 pinia websocket 1 创建pinia文件夹 xff0c 目录如下 src pinia index js modules wsdata js 2 编
  • javascript BOM

    一 什么是BOM xff1a BOM xff08 Browser Object Model xff09 的意思是浏览器对象模型 BOM方法一般指的都是在浏览器 xff08 window xff09 中的方法 二 常见的BOM方法 事件 xf
  • Flutter 利用 FFI,绕过 Android JNI 直接调用 C++ 层!

    坏de牧羊人 作者 承香墨影 校对 https juejin cn post 6976824832595853342 原文 大家好 xff0c 这里是承香墨影 xff01 今天和大家聊聊 Flutter 与 C C 43 43 直接调用的方
  • 前端请求接口浏览器发起option预请求而导致405的问题

    记一次前端请求后端接口出现405的问题 xff1a 问题描述 xff1a 首先阐述http的405状态码 xff0c 405的直接提示是method not allowed xff0c 即前端请求的方法不被后端接受 xff08 如下图 xf
  • 如何变现?互联网商业产品模式详解

    本文由作者 海贝学姐 发布于社区 变现 商业化 商业模式 这些词相信大家都耳熟能详了 懂商业 xff0c 往往能让你在职场上更容易获得上升空间 xff0c 毕竟赚钱是每家企业最重要的目的之一 本文会对互联网商业产品的类型 模式 定价策略和角
  • 连接PC桌面和android手机的神器--scrcpy

    无意中发现一个手机调试和自动化测试的神器 xff0c Scrcpy xff0c 甚是强大 xff0c 探索了一番 xff0c 配合minitouch可以实现更自动化的操作 xff0c 但是也可以用python的pythonautogui这样
  • ubuntu配置远程桌面登录(两端都是ubuntu)

    1 从机 xff08 被访问端 xff09 安装x11vnc 可以ssh登录后安装 sudo apt get install x11vnc y 2 设置访问密码 sudo x11vnc storepasswd etc x11vnc pass

随机推荐