File size: 4,080 Bytes
a60870d
b6fad30
a60870d
cbf7d7d
b6fad30
a60870d
865ddc0
 
84cf670
a60870d
b6fad30
865ddc0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a60870d
 
 
865ddc0
 
 
b6fad30
865ddc0
b6fad30
 
 
 
a60870d
b6fad30
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a60870d
b6fad30
 
 
 
 
 
 
 
 
 
 
 
865ddc0
 
 
b6fad30
 
 
865ddc0
 
b6fad30
865ddc0
 
 
b6fad30
19c8242
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
# https://github.com/THUDM/ChatGLM2-6B

from transformers import AutoTokenizer, AutoModel
import gradio as gr

tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True)
#model = AutoModel.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True, device='cuda')
#model = AutoModel.from_pretrained("THUDM/chatglm2-6b", trust_remote_code=True).float()
model = AutoModel.from_pretrained("THUDM/chatglm2-6b-int4",trust_remote_code=True).float()
model = model.eval()

def generate_prompt(prompt: str, style: str) -> str:
  if len(prompt) == 0:
    return "请输入您的提示语"
  
  generated_prompt = '以“' + prompt + '”为主题,撰写一段' + style + ',字数在100字左右'
  print('功能:' + style + ',generated_prompt:' + generated_prompt)
  
  return generated_prompt

def text_generation(original_prompt: str, generated_prompt: str, style: str) -> str:
  if not len(generated_prompt) == 0:
    prompt = generated_prompt
  elif not len(original_prompt) == 0:
    prompt = original_prompt
  else:
    return "请输入您的提示语"
  
  print('功能:' + style + ',提示语:' + prompt)
  
  response, history = model.chat(tokenizer, prompt, history=[])
    
  result = '按照您的提示语:' + prompt + ',生成的文案如下:\n\n' + response
  
  print(result)

  return result


css_style = "#fixed_size_img {height: 240px;} "

title = "文案创作 by宁侠"
description = '''
本服务的主要应用场景涵盖多种文案输入生成和续写,例如用户可以自行输入各种内容,之后服务将会对其进行回答、续写或者按照指令进行回复。
'''

with gr.Blocks(title=title, css=css_style) as demo:
    gr.HTML('''
      <div style="text-align: center; max-width: 720px; margin: 0 auto;">
                  <div
                    style="
                      display: inline-flex;
                      align-items: center;
                      gap: 0.8rem;
                      font-size: 1.75rem;
                    "
                  >
                    <h1 style="font-family: PingFangSC; font-weight: 500; line-height: 1.5em; font-size: 32px; margin-bottom: 7px;">
                      文案创作
                    </h1>
                    <h1 style="font-family: PingFangSC; font-weight: 500; line-height: 1.5em; font-size: 16px; margin-bottom: 7px;">
                      by宁侠
                    </h1>
                  </div>
                </div>
      ''')

    gr.Markdown(description)
    with gr.Row():
        radio_style = gr.Radio(label="功能选择", choices=["小红书笔记", "小红书标题", "公众号文案", "朋友圈微商文案", "商品卖点", "商品描述", "商品种草文案", "商品好评", "广告标题", "创意广告", "产品起名", "视频拍摄剧本", "短视频口播稿", "直播脚本", "短视频拍摄提纲", "SEO文章", "产品slogan", "夸夸机器人", "诗词创作", "作文创作"], value="小红书笔记")
    with gr.Row():
        original_prompt = gr.Textbox(label="请输入您的提示语", value="探索西夏:沙漠风情与多元文化的西北之旅")
        rich_prompt = gr.Button("一键丰富提示语")
        generated_prompt = gr.Textbox(label="我们为您生成的提示语", value="以“探索西夏:沙漠风情与多元文化的西北之旅”为主题,撰写一段小红书笔记,字数在100字左右")
    with gr.Row():
        btn_submit = gr.Button(value="一键创作", elem_id="blue_btn")
        # btn_clear = gr.Button(value="清除")
    with gr.Row():
        text_output = gr.Textbox(label="生成文案")

    examples = gr.Examples(["探索西夏:沙漠风情与多元文化的西北之旅", "个性iPhone手机壳"], inputs=[original_prompt], outputs=generated_prompt)
    rich_prompt.click(generate_prompt, inputs=[original_prompt, radio_style], outputs=[generated_prompt])
    btn_submit.click(text_generation, inputs=[original_prompt, generated_prompt, radio_style], outputs=text_output)

demo.queue(api_open=False).launch(debug=True)