chatgpt.py 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. """
  2. @author: luojunhui
  3. """
  4. import openai
  5. import requests
  6. class OpenAIServer(object):
  7. """
  8. openai 服务
  9. """
  10. openai.api_key = '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'
  11. proxies = {
  12. 'http': 'http://localhost:1087',
  13. 'https': 'http://localhost:1087'
  14. }
  15. # 创建一个代理会话
  16. session = requests.Session()
  17. session.proxies.update(proxies)
  18. headers = {
  19. 'Authorization': f'Bearer {openai.api_key}',
  20. 'Content-Type': 'application/json',
  21. }
  22. @classmethod
  23. def prompt_generate(cls, prompt_type):
  24. """
  25. 为具体的 task 生成 prompt
  26. :param prompt_type:
  27. :return:
  28. """
  29. if prompt_type == "title":
  30. prompt = """
  31. 请将以上标题改写成适合小程序点击和传播的小程序标题,小程序标题的写作规范如下,请学习后进行小程序标题的编写。直接输出最终的小程序标题
  32. 小程序标题写作规范:
  33. 1.要点前置:将最重要的信息放在标题的最前面,以快速吸引读者的注意力。例如,“5月一辈子同学,三辈子亲,送给我的老同学,听哭无数人!”中的“5月”和“一辈子同学,三辈子亲”都是重要的信息点。
  34. 2.激发情绪:使用能够触动人心的语言,激发读者的情感共鸣。如“只剩两人同学聚会,看后感动落泪。”使用“感动落泪”激发读者的同情和怀旧情绪。
  35. 3.使用数字和特殊符号:数字可以提供具体性,而特殊符号如“🔴”、“😄”、“🔥”等可以吸引视觉注意力,增加点击率。
  36. 4.悬念和好奇心:创建悬念或提出问题,激发读者的好奇心。例如,“太神奇了!长江水位下降,重庆出现惊奇一幕!”中的“惊奇一幕”就是一个悬念。
  37. 5.名人效应:如果内容与知名人士相关,提及他们的名字可以增加标题的吸引力。
  38. 6.社会价值观:触及读者的文化和社会价值观,如家庭、友情、国家荣誉等。
  39. 7.标点符号的运用:使用感叹号、问号等标点来增强语气和情感表达。
  40. 8.直接的语言:使用直白、口语化的语言,易于理解,如“狗屁股,笑死我了!”。
  41. 9.热点人物或事件:提及当前的热点人物或事件,利用热点效应吸引读者。
  42. 10.字数适中:保持标题在10-20个字之间,既不过长也不过短,确保信息的完整性和吸引力。
  43. 11.适当的紧迫感:使用“最新”、“首次”、“紧急”等词汇,创造一种紧迫感,促使读者立即行动。
  44. 12.情感或价值诉求:使用如“感动”、“泪目”、“经典”等词汇,直接与读者的情感或价值观产生共鸣。
  45. 避免误导:确保标题准确反映内容,避免夸大或误导读者。
  46. """
  47. elif prompt_type == "text":
  48. prompt = """
  49. 请从我给你的文章中挖掘出以下信息并且返回如下结果。
  50. 你返回的结果是一个 json, 格式如下:
  51. {
  52. "content_keys": [] # 同时提供三个与文章内容高度相关的关键词,这些关键词将用于网络上搜索相关视频内容,
  53. "content_title": 一个总结性的标题,该标题应简洁并能够反映文章的主要内容
  54. }
  55. 你需要处理的文本是:
  56. """
  57. else:
  58. prompt = "用中文帮我回答以下问题"
  59. return prompt
  60. @classmethod
  61. def gpt_mining(cls, text, prompt):
  62. """
  63. 用 gpt 实现文本挖掘
  64. :param prompt:
  65. :param text:
  66. :return:
  67. """
  68. response = cls.session.post(
  69. url='https://api.openai.com/v1/chat/completions',
  70. headers=cls.headers,
  71. json={
  72. 'model': 'gpt-3.5-turbo',
  73. 'messages': [
  74. {'role': 'system', 'content': '你是一名优秀的中文工作者'},
  75. {'role': 'user', 'content': prompt + text},
  76. ],
  77. }
  78. )
  79. # 解析响应
  80. if response.status_code == 200:
  81. return response.json()['choices'][0]['message']['content']
  82. else:
  83. raise Exception(f"Request failed: {response.status_code} - {response.text}")
  84. @classmethod
  85. def gpt_deal(cls, params):
  86. """
  87. main 函数,处理 gpt 的事务逻辑
  88. :return:
  89. """
  90. title = params['title'].split("@@")[-1]
  91. contents = params['content']
  92. trace_id = params['trace_id']
  93. # 修改 title
  94. title_response = cls.gpt_mining(
  95. text=title,
  96. prompt=cls.prompt_generate(
  97. prompt_type="title"
  98. )
  99. )
  100. print(title_response)
  101. # 挖掘信息
  102. article_response = cls.gpt_mining(
  103. text=contents,
  104. prompt=cls.prompt_generate(
  105. prompt_type="text"
  106. )
  107. )
  108. print(article_response)