gpt4o_help.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. import json
  2. import random
  3. import re
  4. import time
  5. import requests
  6. class GPT4o():
  7. @classmethod
  8. def get_ai_title(cls, old_title):
  9. max_retries = 3
  10. for attempt in range(max_retries):
  11. content = '''
  12. CONTEXT
  13. 你是一名短视频标题优化专家,任务是为短视频生成吸引力高且符合规范的标题。
  14. OBJECTIVE
  15. 基于优秀标题要求及示例,生成新的、吸引用户注意的标题。
  16. SCALE
  17. 如果原标题无法按照规则生成新标题则重新尝试5次,失败后返回None
  18. TIME
  19. 在标题生成请求提出后的1分钟内生成。
  20. ACTOR
  21. 短视频标题优化专家
  22. RESOURCES
  23. - 原标题列表
  24. - 优秀标题示例
  25. - 标题生成规范和约束条件
  26. RESPONSE
  27. 为每个原标题生成符合规范的新标题。
  28. 生成示例标题案例及要求
  29. 1. 标题开头包含醒目emoji🔴,整体字符长度必须控制在10-25个字
  30. 2. 识别需要修改的标题中可能感兴趣的人群,并在标题中表现出来。人群示例如:群友们、退休人员、50~70后等
  31. 3. 标题中可增加一些对内容的观点/态度,用人格化的方式表达,示例:太香了、老外至今难以相信
  32. 4. 标题结尾可以根据标题内容增加一些引导语,格式参考示例但不必局限于示例。示例:你们见过吗、你听对不对、说的太好了、请听、太神奇了
  33. 5. 对于包含#话题和@人的标题,若标题中包含其他元素,则去除#话题和@人元素后利用其他元素生成标题。若标题去除#话题和@人外无其他元素,则仅利用#话题的内容生成标题
  34. Goodcase示例:
  35. ⭕老外至今难以相信,中国人竟能把大桥建到天上,穿入云中
  36. 🔴未来酒店体验,群友们,请看!
  37. ⭕六七十年代的《忠字舞》,你们见过吗?
  38. 🔴哈哈哈!大哥说的太好了!太真实了
  39. 🔴今天,请记住那1700个集体赴死的年轻人,平均23岁!
  40. 🔴这才叫老同学聚会,到了这个年纪,还能聚在一起真不容易!
  41. 🔴百善孝为先,心凉了捂不热了
  42. 🔴养儿不如养狗,一件真实的事!
  43. 🔴让人受益的一段话,写得真好!
  44. 🔴“处暑三劝”!发给最好的朋友劝一劝!
  45. 🔴世间公道自在人心,善恶有报,人生智慧建议收藏!
  46. 🔴坐着电梯登上山顶!这怕是只有中国人敢想敢做!
  47. 🔴人老了!就应该这样去活!
  48. 生成约束
  49. 1. 标题不能包含#话题标签和@人名。
  50. 2. 如果原标题无法按照规则生成新标题则重新尝试5次,失败后返回None。
  51. 3. 不能编造:不能加入原标题没有的实体信息,如原标题没有养老金,不能在生成的标题中出现养老金。
  52. 4. 标题内不能使用强引导分享点击的词句,如:快来看看、大家都听一听、值得一看、都看看吧、你也来看看吧、大家注意、都听听等。
  53. 5. 不能使用无实质信息和强烈诱导点击、紧急、夸张、震惊的描述,避免使用“震惊国人”、“速看”、“太震撼了”等类似描述。
  54. 6. 标题需要简洁、清晰,不要使用网络流行语,如:太燃了、佛系、躺平、内卷等。
  55. badcase示例:
  56. 🌸绝对不能错过,快打开看看,越快越好
  57. 所有老年人一定要看
  58. 天大的好消息,5月开始实施❗
  59. 就在刚刚,中国突然传出重磅消息,所有人都不敢相信! 🚩
  60. 丧尽天良!为什么生病的人越来越多,原来吃的是这些 🎈
  61. 今年的端午节太特殊,一辈子难遇一次!一定要看!错过别后悔
  62. 好消息来了,千万别划走!
  63. 紧急!已爆发,错过就晚了😱
  64. 输出格式:要求输出格式为符合RFC8259标准的JSON格式的字符串,不要以代码块形式返回,返回一个string类型的新标题
  65. '''
  66. url = "http://aigc.piaoquantv.com/aigc-server/aigc/conversation"
  67. headers = {
  68. "Content-Type": "application/json"
  69. }
  70. payload = {
  71. "auth": "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",
  72. "openAiGptParam": {
  73. "model": "gpt-4o",
  74. "temperature": 0.5,
  75. "messages": [
  76. {
  77. "role": "system",
  78. "content": content
  79. },
  80. {
  81. "role": "user",
  82. "content": old_title
  83. }
  84. ]
  85. }
  86. }
  87. wait_time = random.uniform(5, 10)
  88. time.sleep(wait_time)
  89. response = requests.post(url, headers=headers, json=payload)
  90. response = response.json()
  91. try:
  92. match = re.search(r'"[^"]+": "([^"]+)"', str(response))
  93. if match:
  94. if match == 'None':
  95. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  96. title = match.group(1)
  97. if '原标题无法按照规则生成新标题' in title or '原标题不符合生成新标题的要求,请提供符合要求的原标题' in title or 'Invalid input format' in title or "很抱歉,您提供的原标题没有包含在上下文中。请提供具体的原标题列表,以便我为您生成新的标题。" in title or "对不起,我的职责是优化短视频标题" in title or "请提供需要优化的原标题列表。" in title:
  98. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  99. return title
  100. else:
  101. content = response['data']['choices'][0]['message']['content']
  102. if content:
  103. if content == 'None':
  104. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  105. if 'title' in content:
  106. data = json.loads(content)
  107. title = data["title"]
  108. if title:
  109. if '原标题无法按照规则生成新标题' in title or '原标题不符合生成新标题的要求,请提供符合要求的原标题' in title or 'Invalid input format' in title or "很抱歉,您提供的原标题没有包含在上下文中。请提供具体的原标题列表,以便我为您生成新的标题。" in title or "对不起,我的职责是优化短视频标题" in title or "请提供需要优化的原标题列表。" in title:
  110. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  111. return title
  112. elif '新标题' in content:
  113. data = json.loads(content)
  114. title = data['新标题']
  115. if '原标题无法按照规则生成新标题' in title or '原标题不符合生成新标题的要求,请提供符合要求的原标题' in title or 'Invalid input format' in title or "很抱歉,您提供的原标题没有包含在上下文中。请提供具体的原标题列表,以便我为您生成新的标题。" in title or "对不起,我的职责是优化短视频标题" in title or "请提供需要优化的原标题列表。" in title:
  116. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  117. return title
  118. if '"' in content:
  119. if '原标题无法按照规则生成新标题' in content or '原标题不符合生成新标题的要求,请提供符合要求的原标题' in content or 'Invalid input format' in content or "很抱歉,您提供的原标题没有包含在上下文中。请提供具体的原标题列表,以便我为您生成新的标题。" in content or "对不起,我的职责是优化短视频标题" in content or "请提供需要优化的原标题列表。" in content:
  120. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  121. content = content.replace('"', '')
  122. return content
  123. elif attempt == max_retries - 1:
  124. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  125. except Exception:
  126. if attempt == max_retries - 1:
  127. return "这个视频,分享给我的老友,祝愿您能幸福安康"
  128. @classmethod
  129. def get_ai_pw(cls, title):
  130. max_retries = 3
  131. for attempt in range(max_retries):
  132. content = '''
  133. 请针对微信平台视频类小程序场景,面向人群是中国中老年人,在单聊、群聊场景,对不同类型的内容,生成结尾引导分享的脚本。引导用户发生更多的分享行为。要求优化过程综合考虑下面的要求:
  134. 第一.根据下面的示例case,总结分享引导脚本特点,生成分享引导脚本
  135. 示例case1:
  136. 标题:几十年前的老歌,现在很少听到了!
  137. 返回分享引导脚本:
  138. 这个视频真是难得,太美太好听了,看完真是回忆满满,让人怀念那个时代,多么淳朴多么美好,今天大家都在群里转发这个视频,看了都说,那时候虽然手里不宽裕,但心里都满怀希望,那股子拼劲,真是让人热血沸腾,老朋友你还记得吗?如果你也跟我一样深深的怀念,赶紧把这个视频转发到你所有群里去吧,让大家伙都看看吧,多多转发,感恩有你!
  139. 示例case2:
  140. 标题:🔺令人尊敬的老人❗❗这才是我们应该追的明星❗
  141. 返回分享引导脚本:
  142. 这个视频发出来5天了,转发的人却寥寥无几,试想一次明星出轨就全民皆知,这样中国真正的正能量却无人关注,真是太讽刺了!如果你看到了这个视频,请分享到你加入的每个群,向杨老这种无私奉献的大爱致敬!千万别让那些低调做好事的人心寒!转发传递下去,让世界都看到,中华民族的正能量!
  143. 第二:生成过程有如下的规范、约束和建议:
  144. 1.不能编造:不能加入原标题没有的实体信息,如原标题没有养老金,不能在生成的标题中出现养老金;
  145. 2.不能使用强烈的诱导、夸张词汇:在提高分享吸引力的同时,严格落实不使用“必做”、“错过悔恨终生”类描述;
  146. 3.分享引导阅读总字数控制在150个字以内,总时长控制30秒到1分钟,20-30句话,每句话字符长度控制在4-10字;
  147. 输出格式:要求输出格式为符合RFC8259标准的JSON格式的字符串,不要以代码块形式返回,返回一个string类型的分享引导脚本内容。
  148. '''
  149. url = "http://aigc.piaoquantv.com/aigc-server/aigc/conversation"
  150. headers = {
  151. "Content-Type": "application/json"
  152. }
  153. payload = {
  154. "auth": "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",
  155. "openAiGptParam": {
  156. "model": "gpt-4o",
  157. "temperature": 0.5,
  158. "messages": [
  159. {
  160. "role": "system",
  161. "content": content
  162. },
  163. {
  164. "role": "user",
  165. "content": title
  166. }
  167. ]
  168. }
  169. }
  170. wait_time = random.uniform(5, 20)
  171. time.sleep(wait_time)
  172. response = requests.post(url, headers=headers, json=payload)
  173. response = response.json()
  174. try:
  175. content = response['data']['choices'][0]['message']['content']
  176. pattern = re.compile(r'"分享引导脚本":\s*"(.*?)"')
  177. match = pattern.search(content)
  178. if match:
  179. pw = match.group(1)
  180. # 检查文本中是否包含英文字母
  181. if re.search(r'[a-zA-Z]', pw):
  182. pw = re.sub(r'[a-zA-Z]', '', pw)
  183. return pw
  184. else:
  185. if content:
  186. if re.search(r'[a-zA-Z]', content):
  187. content = re.sub(r'[a-zA-Z]', '', content)
  188. return content
  189. if attempt == max_retries - 1:
  190. return None
  191. except Exception:
  192. if attempt == max_retries - 1:
  193. return None
  194. if __name__ == '__main__':
  195. title = '如果有人跟你说苍蝇不叮无缝的蛋,你怎么回'
  196. GPT4o.get_ai_title(title)