fix: 修复神秘formatter
This commit is contained in:
@@ -8,8 +8,7 @@ from snownlp import SnowNLP
|
||||
from ..models.utils_model import LLM_request
|
||||
|
||||
driver = get_driver()
|
||||
config = driver.config
|
||||
|
||||
config = driver.config
|
||||
|
||||
class TopicIdentifier:
|
||||
def __init__(self):
|
||||
@@ -18,11 +17,11 @@ class TopicIdentifier:
|
||||
async def identify_topic_llm(self, text: str) -> Optional[List[str]]:
|
||||
"""识别消息主题,返回主题列表"""
|
||||
|
||||
prompt = f"""判断这条消息的主题,如果没有明显主题请回复"无主题",要求:\
|
||||
1. 主题通常2-4个字,必须简短,要求精准概括,不要太具体。\
|
||||
2. 建议给出多个主题,之间用英文逗号分割。只输出主题本身就好,不要有前后缀。\
|
||||
3. 这里是
|
||||
消息内容:{text}"""
|
||||
prompt = f"""判断这条消息的主题,如果没有明显主题请回复"无主题",要求:
|
||||
1. 主题通常2-4个字,必须简短,要求精准概括,不要太具体。
|
||||
2. 建议给出多个主题,之间用英文逗号分割。只输出主题本身就好,不要有前后缀。
|
||||
|
||||
消息内容:{text}"""
|
||||
|
||||
# 使用 LLM_request 类进行请求
|
||||
topic, _ = await self.llm_client.generate_response(prompt)
|
||||
@@ -44,181 +43,25 @@ class TopicIdentifier:
|
||||
words = jieba.lcut(text)
|
||||
# 去除停用词和标点符号
|
||||
stop_words = {
|
||||
"的",
|
||||
"了",
|
||||
"和",
|
||||
"是",
|
||||
"就",
|
||||
"都",
|
||||
"而",
|
||||
"及",
|
||||
"与",
|
||||
"这",
|
||||
"那",
|
||||
"但",
|
||||
"然",
|
||||
"却",
|
||||
"因为",
|
||||
"所以",
|
||||
"如果",
|
||||
"虽然",
|
||||
"一个",
|
||||
"我",
|
||||
"你",
|
||||
"他",
|
||||
"她",
|
||||
"它",
|
||||
"我们",
|
||||
"你们",
|
||||
"他们",
|
||||
"在",
|
||||
"有",
|
||||
"个",
|
||||
"把",
|
||||
"被",
|
||||
"让",
|
||||
"给",
|
||||
"从",
|
||||
"向",
|
||||
"到",
|
||||
"又",
|
||||
"也",
|
||||
"很",
|
||||
"啊",
|
||||
"吧",
|
||||
"呢",
|
||||
"吗",
|
||||
"呀",
|
||||
"哦",
|
||||
"哈",
|
||||
"么",
|
||||
"嘛",
|
||||
"啦",
|
||||
"哎",
|
||||
"唉",
|
||||
"哇",
|
||||
"嗯",
|
||||
"哼",
|
||||
"哪",
|
||||
"什么",
|
||||
"怎么",
|
||||
"为什么",
|
||||
"怎样",
|
||||
"如何",
|
||||
"什么样",
|
||||
"这样",
|
||||
"那样",
|
||||
"这么",
|
||||
"那么",
|
||||
"多少",
|
||||
"几",
|
||||
"谁",
|
||||
"哪里",
|
||||
"哪儿",
|
||||
"什么时候",
|
||||
"何时",
|
||||
"为何",
|
||||
"怎么办",
|
||||
"怎么样",
|
||||
"这些",
|
||||
"那些",
|
||||
"一些",
|
||||
"一点",
|
||||
"一下",
|
||||
"一直",
|
||||
"一定",
|
||||
"一般",
|
||||
"一样",
|
||||
"一会儿",
|
||||
"一边",
|
||||
"一起",
|
||||
'的', '了', '和', '是', '就', '都', '而', '及', '与', '这', '那', '但', '然', '却',
|
||||
'因为', '所以', '如果', '虽然', '一个', '我', '你', '他', '她', '它', '我们', '你们',
|
||||
'他们', '在', '有', '个', '把', '被', '让', '给', '从', '向', '到', '又', '也', '很',
|
||||
'啊', '吧', '呢', '吗', '呀', '哦', '哈', '么', '嘛', '啦', '哎', '唉', '哇', '嗯',
|
||||
'哼', '哪', '什么', '怎么', '为什么', '怎样', '如何', '什么样', '这样', '那样', '这么',
|
||||
'那么', '多少', '几', '谁', '哪里', '哪儿', '什么时候', '何时', '为何', '怎么办',
|
||||
'怎么样', '这些', '那些', '一些', '一点', '一下', '一直', '一定', '一般', '一样',
|
||||
'一会儿', '一边', '一起',
|
||||
# 添加更多量词
|
||||
"个",
|
||||
"只",
|
||||
"条",
|
||||
"张",
|
||||
"片",
|
||||
"块",
|
||||
"本",
|
||||
"册",
|
||||
"页",
|
||||
"幅",
|
||||
"面",
|
||||
"篇",
|
||||
"份",
|
||||
"朵",
|
||||
"颗",
|
||||
"粒",
|
||||
"座",
|
||||
"幢",
|
||||
"栋",
|
||||
"间",
|
||||
"层",
|
||||
"家",
|
||||
"户",
|
||||
"位",
|
||||
"名",
|
||||
"群",
|
||||
"双",
|
||||
"对",
|
||||
"打",
|
||||
"副",
|
||||
"套",
|
||||
"批",
|
||||
"组",
|
||||
"串",
|
||||
"包",
|
||||
"箱",
|
||||
"袋",
|
||||
"瓶",
|
||||
"罐",
|
||||
'个', '只', '条', '张', '片', '块', '本', '册', '页', '幅', '面', '篇', '份',
|
||||
'朵', '颗', '粒', '座', '幢', '栋', '间', '层', '家', '户', '位', '名', '群',
|
||||
'双', '对', '打', '副', '套', '批', '组', '串', '包', '箱', '袋', '瓶', '罐',
|
||||
# 添加更多介词
|
||||
"按",
|
||||
"按照",
|
||||
"把",
|
||||
"被",
|
||||
"比",
|
||||
"比如",
|
||||
"除",
|
||||
"除了",
|
||||
"当",
|
||||
"对",
|
||||
"对于",
|
||||
"根据",
|
||||
"关于",
|
||||
"跟",
|
||||
"和",
|
||||
"将",
|
||||
"经",
|
||||
"经过",
|
||||
"靠",
|
||||
"连",
|
||||
"论",
|
||||
"通过",
|
||||
"同",
|
||||
"往",
|
||||
"为",
|
||||
"为了",
|
||||
"围绕",
|
||||
"于",
|
||||
"由",
|
||||
"由于",
|
||||
"与",
|
||||
"在",
|
||||
"沿",
|
||||
"沿着",
|
||||
"依",
|
||||
"依照",
|
||||
"以",
|
||||
"因",
|
||||
"因为",
|
||||
"用",
|
||||
"由",
|
||||
"与",
|
||||
"自",
|
||||
"自从",
|
||||
'按', '按照', '把', '被', '比', '比如', '除', '除了', '当', '对', '对于',
|
||||
'根据', '关于', '跟', '和', '将', '经', '经过', '靠', '连', '论', '通过',
|
||||
'同', '往', '为', '为了', '围绕', '于', '由', '由于', '与', '在', '沿', '沿着',
|
||||
'依', '依照', '以', '因', '因为', '用', '由', '与', '自', '自从'
|
||||
}
|
||||
|
||||
|
||||
# 过滤掉停用词和标点符号,只保留名词和动词
|
||||
filtered_words = []
|
||||
for word in words:
|
||||
@@ -231,16 +74,16 @@ class TopicIdentifier:
|
||||
'≈', '∈', '∉', '⊆', '⊇', '⊂', '⊃', '∪', '∩', '∧', '∨'
|
||||
}:
|
||||
filtered_words.append(word)
|
||||
|
||||
|
||||
# 统计词频
|
||||
word_freq = {}
|
||||
for word in filtered_words:
|
||||
word_freq[word] = word_freq.get(word, 0) + 1
|
||||
|
||||
|
||||
# 按词频排序,取前3个
|
||||
sorted_words = sorted(word_freq.items(), key=lambda x: x[1], reverse=True)
|
||||
top_words = [word for word, freq in sorted_words[:3]]
|
||||
|
||||
|
||||
return top_words if top_words else None
|
||||
|
||||
def identify_topic_snownlp(self, text: str) -> Optional[List[str]]:
|
||||
@@ -264,4 +107,4 @@ class TopicIdentifier:
|
||||
print(f"\033[1;31m[错误]\033[0m SnowNLP 处理失败: {str(e)}")
|
||||
return None
|
||||
|
||||
topic_identifier = TopicIdentifier()
|
||||
topic_identifier = TopicIdentifier()
|
||||
Reference in New Issue
Block a user