草庐IT

Python - Gradio 文档使用心得与文档解读

DreamingBetter 2023-04-27 原文

前言

官方文档
我也是第一天看,第一天用,读文档和使用过程遇到的情况浅浅记录一下,直接进入正题。

创建Interface实例

这是Interface的参数

gradio.Interface(self, fn, inputs=None, outputs=None, examples=None, examples_per_page=10, live=False, layout="unaligned", 
interpretation=None, num_shap=2.0, theme=None, title=None, description=None, article=None, thumbnail=None, css=None, 
allow_flagging=None, flagging_options=None, flagging_dir="flagged")

这么一大坨参数看着也头晕,我们挑几个(对于我自身使用而言)较为常用参数来看:
(最主要三个参数即可创建实例,fn、inputs、outputs)

gradio.Interface(self, fn, inputs=None, outputs=None, live=False, layout='unaligned', allow_flagging=None, flagging_dir="flagged")

注:Union表示集合、包含的意思,例如inputs,可以是字符串str;可以是输入组件InputComponent;可以是列表,列表可以包含字符串str,输入组件InputComponent。

  • fn(Union[Callable, List[Callable]]):包装的函数,可以是一个或者多个,用列表存放多个函数。
  • inputs(Union[str, InputComponent, List[Union[str, InputComponent]]]):输入类型/格式,一个参数可以是字符串str;可以是输入组件InputComponent;多个参数可以是列表,列表可以包含字符串str,输入组件InputComponent。输入组件的个数应该和fn函数的参数个数一致。
  • outputs(Union[str, OutputComponent, List[Union[str, OutputComponent]]]):输出类型/格式,与inputs类似,区别就算这是输出组件。输出组件的个数应该和fn函数返回个数一致。
  • live(bool):默认为False,设置为True,为动态页面,只要输入发生变化,结果马上发生改变。
  • layout(str):输入输出面板的布局。"horizontal"安排他们为两列等高;"unaligned"安排他们为两列不等高;"vertical"安排他们为垂直排放。
  • allow_flagging(str):有三个选项"never"、“auto”、“manual”。设置为"never"或"auto"时,用户无法看到Flag按钮;设置为"manual",用户可见Flag按钮。如果设置为"auto",每次的输入输出都会被标记保存。如果设置为"manual",当用户按下Flag按钮,标记当前输入输出的结果并保存。
  • flagging_dir(str):Flag保存的文件夹名称

发射Interface

gradio.Interface().launch(self)

也是那几个(对于我自身使用而言)较为常用参数来看:
(无需参数,可直接调用,为本地链接)

  • share(bool):是否创建可公开分享的链接。
  • auth(Callable, Union[Tuple[str, str], List[Tuple[str, str]]]):最简单的就是给个用户名、密码的元组,这样就可以让有权限的人才能访问。

输入组件(只解释我认为的较为常用)

  • Textbox
gradio.inputs.Textbox(self, lines=1, placeholder=None, default="", label=None, optional=False)

该组件为用户提供一个输入框,需提供一个字符串为参数的包装函数
输入类型:str

参数:
lines (int) - 输入区域行数
placeholder (str) - placeholder学过前端的应该都知道,就是在输入框中的一个提示文本。
default (str) - 默认文本
label (str) - 在接口中的该输入组件的组件名(下面所有组件同理)
optional (bool) - 这个参数忽略(官方文档这么写的)

字符串快捷键:(即不需要实例化Textbox对象)
“text” - 使用默认参数
“textbox” - 设置 lines=7

  • Number
gradio.inputs.Number(self, default=None, label=None, optional=False)

该组件为用户提供一个数字输入框,需提供一个数字为参数的包装函数
输入类型:float

参数:
default (float) - 默认值
label (str) - 组件名
optional (bool) - 如果为True,可以没输入值就点击Submit提交

字符串快捷键:
“number” - 使用默认参数

  • Slider
gradio.inputs.Slider(self, minimum=0, maximum=100, step=None, default=None, label=None, optional=False)

该组件为用户提供一个最小值到最大值的区间滑块,需提供一个数字为参数的包装函数
输入类型:float

参数:
minimum (float) - 最小值
maximum (float) - 最大值
step (float) - 步长
default (float) - 默认值
label (str) - 组件名
optional (bool) - 这个参数忽略

字符串快捷键:
“slider” - 使用默认参数

  • Checkbox
gradio.inputs.Checkbox(self, default=False, label=None, optional=False)

该组件为用户提供单个复选框,可选可不选,需提供一个bool为参数的包装函数
输入类型:bool

参数:
label (str) - 组件名
default (bool) - 如果为True,默认选中
optional (bool) - 这个参数忽略

字符串快捷键:
“checkbox” - 使用默认参数

  • CheckboxGroup
gradio.inputs.CheckboxGroup(self, choices, default=[], type="value", label=None, optional=False)

该组件为用户提供多个复选框,需提供一个作为选项内容的字符串列表为参数的包装函数
输入类型:Union[List[str], List[int]]

参数:
choices (List[str]) - 选项列表
default (List[str]) - 默认选中的选项列表
type (str) - 组件返回值的类型(就是用户选择后,返回给我们以什么类型处理)。 “value” 返回所选选项的字符串列表, “index” 返回所选选项的索引列表。
label (str) - 组件名
optional (bool) - 这个参数忽略

  • Radio
gradio.inputs.Radio(self, choices, type="value", default=None, label=None, optional=False)

该组件为用户提供多个单选框按钮,需提供一个被选择的字符串为参数的包装函数
输入类型:Union[str, int]

参数:
choices (List[str]) - 选项列表
type (str) - 组件返回值的类型(就是用户选择后,返回给我们以什么类型处理)。 “value” 返回所选选项的字符串, “index” 返回所选选项的索引。
default (str) - 默认选择的按钮,如果为None, 则没有默认选择。
label (str) - 组件名
optional (bool) - 这个参数忽略

  • Dropdown
gradio.inputs.Dropdown(self, choices, type="value", default=None, label=None, optional=False)

该组件为用户提供只能选择一个的下拉框,需提供一个被选择的字符串为参数的包装函数
输入类型:Union[str, int]

参数:(与Radio一样)
choices (List[str]) - 选项列表
type (str) - 组件返回值的类型(就是用户选择后,返回给我们以什么类型处理)。 “value” 返回所选选项的字符串, “index” 返回所选选项的索引。
default (str) - 默认选择的按钮,如果为None, 则没有默认选择。
label (str) - 组件名
optional (bool) - 这个参数忽略

  • Image
  • Video
  • Audio
  • File
gradio.inputs.File(self, file_count="single", type="file", label=None, optional=False)

该组件接受通用文件上传
输入类型:Union[file-object, bytes, List[Union[file-object, bytes]]]

参数:(与Radio一样)
file_count (str) - 如果为"single",只允许上传单个文件。 如果为 “multiple”,可以上传多个文件。如果为 “directory”, 可以上传一个文件夹。如果为"multiple" 或 “directory"返回类型是每个文件的列表。
type (str) - 组件返回值的类型。 “file” 返回一个临时文件对象,路径可以通过file_obj.name获取。 “binary” returns an bytes object. (文档写的binary)实际使用报错信息发现还是得用"bytes”,返回一个字节对象。
label (str) - 组件名
optional (bool) - 如果为True,可以不上传文件,此时输入值为None

  • Dataframe
  • Timeseries
  • State

输出组件(只解释目前我用到的)

  • Textbox
gradio.outputs.Textbox(self, type="auto", label=None)

该组件创建一个文本框放输出的文本或数字
输出类型:Union[str, float, int]

参数:
type (str) - 传回组件的类型。“str” 期待一个字符串,“number” 期待一个float,“auto” 自动检测返回类型。.
label (str) - 组件名

字符串快捷键:
“text” - 设置 type=str
“textbox” - 设置 type=str
“number” - 设置 type=number

  • Label
  • Image
  • Video
  • KeyValues
  • HighlightedText
  • Audio
  • JSON
  • HTML
  • File
gradio.outputs.File(self, label=None)

该组件用于文件输出
输出类型:Union[file-like, str]

参数:
label (str) - 组件名

字符串快捷键:
“file” - 使用默认参数

  • Dataframe
  • Carousel
  • Timeseries
  • Chatbot
  • State

*此文仅为个人笔记

有关Python - Gradio 文档使用心得与文档解读的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - 在 Ruby 中使用匿名模块 - 2

    假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

  6. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  7. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  8. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  9. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  10. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

随机推荐