2022-09-15 23:24:10 +08:00
|
|
|
import gradio as gr
|
|
|
|
import os
|
|
|
|
|
|
|
|
# save your HF API token from https:/hf.co/settings/tokens as an env variable to avoid rate limiting
|
2023-11-16 03:31:26 +08:00
|
|
|
hf_token = os.getenv("hf_token")
|
2022-09-15 23:24:10 +08:00
|
|
|
|
2024-07-30 13:08:51 +08:00
|
|
|
# load a model from https://hf.co/models as an interface, then use it as an api
|
|
|
|
# you can remove the hf_token parameter if you don't care about rate limiting.
|
2023-11-16 03:31:26 +08:00
|
|
|
api = gr.load("huggingface/gpt2-xl", hf_token=hf_token)
|
2022-09-15 23:24:10 +08:00
|
|
|
|
|
|
|
def complete_with_gpt(text):
|
|
|
|
return text[:-50] + api(text[-50:])
|
|
|
|
|
|
|
|
with gr.Blocks() as demo:
|
|
|
|
textbox = gr.Textbox(placeholder="Type here...", lines=4)
|
|
|
|
btn = gr.Button("Autocomplete")
|
2024-07-30 13:08:51 +08:00
|
|
|
|
2022-09-15 23:24:10 +08:00
|
|
|
# define what will run when the button is clicked, here the textbox is used as both an input and an output
|
|
|
|
btn.click(fn=complete_with_gpt, inputs=textbox, outputs=textbox, queue=False)
|
|
|
|
|
2024-07-30 13:08:51 +08:00
|
|
|
demo.launch()
|