my_gradio / guides /cn /04_integrating-other-frameworks /01_using-hugging-face-integrations.md
xray918's picture
Upload folder using huggingface_hub
0ad74ed verified

A newer version of the Gradio SDK is available: 5.9.1

Upgrade

使用 Hugging Face 集成

相关空间:https://huggingface.co/spaces/gradio/helsinki_translation_en_es 标签:HUB,SPACES,EMBED

Omar Sanseviero 贡献🦙

介绍

Hugging Face Hub 是一个集成平台,拥有超过 190,000 个模型,32,000 个数据集和 40,000 个演示,也被称为 Spaces。虽然 Hugging Face 以其🤗 transformers 和 diffusers 库而闻名,但 Hub 还支持许多机器学习库,如 PyTorch,TensorFlow,spaCy 等,涵盖了从计算机视觉到强化学习等各个领域。

Gradio 拥有多个功能,使其非常容易利用 Hub 上的现有模型和 Spaces。本指南将介绍这些功能。

使用 pipeline 进行常规推理

首先,让我们构建一个简单的界面,将英文翻译成西班牙文。在赫尔辛基大学共享的一千多个模型中,有一个现有模型,名为 opus-mt-en-es,可以正好做到这一点!

🤗 transformers 库有一个非常易于使用的抽象层,pipeline()处理大部分复杂代码,为常见任务提供简单的 API。通过指定任务和(可选)模型,您可以使用几行代码使用现有模型:

import gradio as gr

from transformers import pipeline

pipe = pipeline("translation", model="Helsinki-NLP/opus-mt-en-es")

def predict(text):
  return pipe(text)[0]["translation_text"]

demo = gr.Interface(
  fn=predict,
  inputs='text',
  outputs='text',
)

demo.launch()

但是,gradio 实际上使将 pipeline 转换为演示更加容易,只需使用 gradio.Interface.from_pipeline 方法,无需指定输入和输出组件:

from transformers import pipeline
import gradio as gr

pipe = pipeline("translation", model="Helsinki-NLP/opus-mt-en-es")

demo = gr.Interface.from_pipeline(pipe)
demo.launch()

上述代码生成了以下界面,您可以在浏览器中直接尝试:

Using Hugging Face Inference Endpoints

Hugging Face 提供了一个名为Serverless Inference Endpoints的免费服务,允许您向 Hub 中的模型发送 HTTP 请求。对于基于 transformers 或 diffusers 的模型,API 的速度可以比自己运行推理快 2 到 10 倍。该 API 是免费的(受速率限制),您可以在想要在生产中使用时切换到专用的推理端点

让我们尝试使用推理 API 而不是自己加载模型的方式进行相同的演示。鉴于 Inference Endpoints 支持的 Hugging Face 模型,Gradio 可以自动推断出预期的输入和输出,并进行底层服务器调用,因此您不必担心定义预测函数。以下是代码示例!

import gradio as gr

demo = gr.load("Helsinki-NLP/opus-mt-en-es", src="models")

demo.launch()

请注意,我们只需指定模型名称并说明 src 应为 models(Hugging Face 的 Model Hub)。由于您不会在计算机上加载模型,因此无需安装任何依赖项(除了 gradio)。

您可能会注意到,第一次推理大约需要 20 秒。这是因为推理 API 正在服务器中加载模型。之后您会获得一些好处:

  • 推理速度更快。
  • 服务器缓存您的请求。
  • 您获得内置的自动缩放功能。

托管您的 Gradio 演示

Hugging Face Spaces允许任何人免费托管其 Gradio 演示,上传 Gradio 演示只需几分钟。您可以前往hf.co/new-space,选择 Gradio SDK,创建一个 app.py 文件,完成!您将拥有一个可以与任何人共享的演示。要了解更多信息,请阅读此指南以使用网站在 Hugging Face Spaces 上托管

或者,您可以通过使用huggingface_hub client library库来以编程方式创建一个 Space。这是一个示例:

from huggingface_hub import (
    create_repo,
    get_full_repo_name,
    upload_file,
)
create_repo(name=target_space_name, token=hf_token, repo_type="space", space_sdk="gradio")
repo_name = get_full_repo_name(model_id=target_space_name, token=hf_token)
file_url = upload_file(
    path_or_fileobj="file.txt",
    path_in_repo="app.py",
    repo_id=repo_name,
    repo_type="space",
    token=hf_token,
)

在这里,create_repo 使用特定帐户的 Write Token 在特定帐户下创建一个带有目标名称的 gradio repo。repo_name 获取相关存储库的完整存储库名称。最后,upload_file 将文件上传到存储库中,并将其命名为 app.py

在其他网站上嵌入您的 Space 演示

在本指南中,您已经看到了许多嵌入的 Gradio 演示。您也可以在自己的网站上这样做!第一步是创建一个包含您想展示的演示的 Hugging Face Space。然后,按照此处的步骤将 Space 嵌入到您的网站上

从 Spaces 加载演示

您还可以在 Hugging Face Spaces 上使用和混合现有的 Gradio 演示。例如,您可以将两个现有的 Gradio 演示放在单独的选项卡中并创建一个新的演示。您可以在本地运行此新演示,或将其上传到 Spaces,为混合和创建新的演示提供无限可能性!

以下是一个完全实现此目标的示例:

import gradio as gr

with gr.Blocks() as demo:
  with gr.Tab("Translate to Spanish"):
    gr.load("gradio/helsinki_translation_en_es", src="spaces")
  with gr.Tab("Translate to French"):
    gr.load("abidlabs/en2fr", src="spaces")

demo.launch()

请注意,我们使用了 gr.load(),这与使用推理 API 加载模型所使用的方法相同。但是,在这里,我们指定 srcspaces(Hugging Face Spaces)。

小结

就是这样!让我们回顾一下 Gradio 和 Hugging Face 共同工作的各种方式:

  1. 您可以使用 from_pipeline()transformers pipeline 转换为 Gradio 演示
  2. 您可以使用 gr.load() 轻松地围绕推理 API 构建演示,而无需加载模型
  3. 您可以在 Hugging Face Spaces 上托管您的 Gradio 演示,可以使用 GUI 或完全使用 Python。
  4. 您可以将托管在 Hugging Face Spaces 上的 Gradio 演示嵌入到自己的网站上。
  5. 您可以使用 gr.load() 从 Hugging Face Spaces 加载演示,以重新混合和创建新的 Gradio 演示。

🤗