kimi.py 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. """
  2. @author: luojunhui
  3. """
  4. import os
  5. import json
  6. from openai import OpenAI
  7. from applications.functions.log import logging
  8. class KimiServer(object):
  9. """
  10. Kimi Server
  11. """
  12. @classmethod
  13. async def search_kimi_schedule(cls, params):
  14. """
  15. 搜索阶段 kimi 操作
  16. :param params:
  17. :return:
  18. """
  19. title = params['title'].split("@@")[-1]
  20. contents = params['content']
  21. trace_id = params['trace_id']
  22. title_p = os.path.join(os.getcwd(), 'applications', 'static', "titles", "{}.json".format(title))
  23. if os.path.exists(title_p):
  24. logging(
  25. code="2001",
  26. info="该标题已经被 kimi 处理过,跳过请求 kimi 操作--- {}".format(title),
  27. function="search_videos_from_the_web",
  28. trace_id=trace_id
  29. )
  30. else:
  31. await cls.ask_kimi_and_save_to_local((title, trace_id, title_p))
  32. kimi_title = await cls.kimi_title(title)
  33. kimi_info = await cls.kimi_mining(contents)
  34. kimi_info['k_title'] = kimi_title
  35. kimi_info['ori_title'] = title
  36. logging(
  37. code="8000",
  38. info="kimi_mining",
  39. data=kimi_info,
  40. trace_id=trace_id
  41. )
  42. return kimi_info
  43. @classmethod
  44. async def ask_kimi(cls, question):
  45. """
  46. Ask Kimi for information
  47. :param question: tiny text
  48. :return: "{}"
  49. """
  50. single_title_prompt = """
  51. 我会给你一个视频标题,需要你帮我用你所学的知识来帮我分析出以下信息,信息我都写到 json 里面了
  52. {
  53. "key_words": [], # 返回三个关键词
  54. "search_keys": [], # 标题可能的搜索关键词,返回 3 个
  55. "extra_keys": [], # 关心这个视频的用户还会关心哪些关键词, 返回 3 个
  56. "theme": 标题的主题, 用一个词概括
  57. }
  58. 只需要返回一个 json,key 和上面的一样,
  59. 我给你的标题是:
  60. """
  61. client = OpenAI(
  62. api_key='sk-tz1VaKqksTzk0F8HxlU4YVGwj7oa1g0c0puGNUZrdn9MDtzm',
  63. base_url="https://api.moonshot.cn/v1"
  64. )
  65. chat_completion = client.chat.completions.create(
  66. messages=[
  67. {
  68. "role": "user",
  69. "content": single_title_prompt + question,
  70. }
  71. ],
  72. model="moonshot-v1-8k",
  73. )
  74. response = chat_completion.choices[0].message.content.replace('```json', '').replace('```', '')
  75. try:
  76. response = json.loads(response)
  77. return response
  78. except:
  79. return {}
  80. @classmethod
  81. async def ask_kimi_and_save_to_local(cls, info_tuple):
  82. """
  83. save file to local
  84. :return:
  85. """
  86. title, trace_id, save_path = info_tuple[0], info_tuple[1], info_tuple[2]
  87. if os.path.exists(save_path):
  88. logging(
  89. code="2001",
  90. info="该 video 信息已经挖掘完成---{}".format(title),
  91. function="ask_kimi_and_save_to_local",
  92. trace_id=trace_id,
  93. )
  94. else:
  95. os.makedirs(os.path.dirname(save_path), exist_ok=True)
  96. if not title:
  97. result = {}
  98. else:
  99. result = await cls.ask_kimi(title)
  100. logging(
  101. code="2001",
  102. info="kimi-result",
  103. data=result,
  104. trace_id=trace_id,
  105. function="ask_kimi_and_save_to_local"
  106. )
  107. with open(save_path, "w", encoding="utf-8") as f:
  108. f.write(json.dumps(result, ensure_ascii=False))
  109. @classmethod
  110. async def kimi_title(cls, ori_title):
  111. """
  112. prompt + kimi + ori_title generate new title
  113. :param ori_title:
  114. :return:
  115. """
  116. single_title_prompt = """
  117. 请将以上标题改写成适合小程序点击和传播的小程序标题,小程序标题的写作规范如下,请学习后进行小程序标题的编写。直接输出最终的小程序标题
  118. 小程序标题写作规范:
  119. 1.要点前置:将最重要的信息放在标题的最前面,以快速吸引读者的注意力。例如,“5月一辈子同学,三辈子亲,送给我的老同学,听哭无数人!”中的“5月”和“一辈子同学,三辈子亲”都是重要的信息点。
  120. 2.激发情绪:使用能够触动人心的语言,激发读者的情感共鸣。如“只剩两人同学聚会,看后感动落泪。”使用“感动落泪”激发读者的同情和怀旧情绪。
  121. 3.使用数字和特殊符号:数字可以提供具体性,而特殊符号如“🔴”、“😄”、“🔥”等可以吸引视觉注意力,增加点击率。
  122. 4.悬念和好奇心:创建悬念或提出问题,激发读者的好奇心。例如,“太神奇了!长江水位下降,重庆出现惊奇一幕!”中的“惊奇一幕”就是一个悬念。
  123. 5.名人效应:如果内容与知名人士相关,提及他们的名字可以增加标题的吸引力。
  124. 6.社会价值观:触及读者的文化和社会价值观,如家庭、友情、国家荣誉等。
  125. 7.标点符号的运用:使用感叹号、问号等标点来增强语气和情感表达。
  126. 8.直接的语言:使用直白、口语化的语言,易于理解,如“狗屁股,笑死我了!”。
  127. 9.热点人物或事件:提及当前的热点人物或事件,利用热点效应吸引读者。
  128. 10.字数适中:保持标题在10-20个字之间,既不过长也不过短,确保信息的完整性和吸引力。
  129. 11.适当的紧迫感:使用“最新”、“首次”、“紧急”等词汇,创造一种紧迫感,促使读者立即行动。
  130. 12.情感或价值诉求:使用如“感动”、“泪目”、“经典”等词汇,直接与读者的情感或价值观产生共鸣。
  131. 避免误导:确保标题准确反映内容,避免夸大或误导读者。
  132. """
  133. client = OpenAI(
  134. api_key='sk-tz1VaKqksTzk0F8HxlU4YVGwj7oa1g0c0puGNUZrdn9MDtzm',
  135. base_url="https://api.moonshot.cn/v1"
  136. )
  137. chat_completion = client.chat.completions.create(
  138. messages=[
  139. {
  140. "role": "user",
  141. "content": ori_title + "\n" + single_title_prompt,
  142. }
  143. ],
  144. model="moonshot-v1-8k",
  145. )
  146. response = chat_completion.choices[0].message.content
  147. return response.split("\n")[0]
  148. @classmethod
  149. async def kimi_mining(cls, text):
  150. """
  151. 通过文章来挖掘出有效的信息
  152. :param text:
  153. :return:
  154. """
  155. text_prompt = """
  156. 请从我给你的文章中挖掘出以下信息并且返回如下结果。
  157. 你返回的结果是一个 json, 格式如下:
  158. {
  159. "content_keys": [] # 同时提供三个与文章内容高度相关的关键词,这些关键词将用于网络上搜索相关视频内容,
  160. "content_title": 一个总结性的标题,该标题应简洁并能够反映文章的主要内容
  161. }
  162. 你需要处理的文本是:
  163. """
  164. client = OpenAI(
  165. api_key='sk-tz1VaKqksTzk0F8HxlU4YVGwj7oa1g0c0puGNUZrdn9MDtzm',
  166. base_url="https://api.moonshot.cn/v1"
  167. )
  168. chat_completion = client.chat.completions.create(
  169. messages=[
  170. {
  171. "role": "user",
  172. "content": text_prompt + text,
  173. }
  174. ],
  175. model="moonshot-v1-8k",
  176. )
  177. response = chat_completion.choices[0].message.content.replace('```json', '').replace('```', '')
  178. try:
  179. response = json.loads(response)
  180. return response
  181. except:
  182. return {}