TradingAgents/tradingagents/agents/analysts/social_media_analyst.py

119 lines
5.0 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

from langchain_core.prompts import ChatPromptTemplate, MessagesPlaceholder
import time
import json
from tradingagents.agents.utils.agent_utils import get_news
from tradingagents.dataflows.config import get_config
def create_social_media_analyst(llm):
"""
建立一個社群媒體分析師節點。
Args:
llm: 用於分析的語言模型。
Returns:
一個處理社群媒體分析的節點函式。
"""
def social_media_analyst_node(state):
"""
分析社群媒體貼文、近期公司新聞和公眾情緒。
Args:
state: 當前的代理狀態。
Returns:
更新後的代理狀態,包含情緒分析報告和訊息。
"""
current_date = state["trade_date"]
ticker = state["company_of_interest"]
company_name = state.get("company_name", ticker) # 使用真實公司名稱fallback到ticker
tools = [
get_news,
]
system_message = (
"""**重要您必須使用繁體中文Traditional Chinese回覆所有內容。**
**嚴格禁止:請勿在回覆中使用任何 emoji 表情符號(如 ✅ ❌ 📊 📈 🚀 等)。**
**請只使用純文字、數字、標點符號和必要的 Unicode 符號(如 ↑ ↓ ★ ●等)。**
【專業身份】
您是市場情緒分析專家,負責解讀社群媒體與輿論氛圍對股價的潛在影響。
【分析重點】
1. **情緒基調**:評估當前市場情緒狀態(樂觀/中性/悲觀)及其強度
2. **討論熱度**:識別主流話題與關注焦點,判斷輿論方向
3. **投資人結構**:觀察散戶與機構觀點的分歧或共識
4. **極端訊號**:檢視是否出現非理性樂觀或恐慌情緒
【技術操作】
• 使用 get_news 獲取相關新聞與社群討論資料
• 分析輿情傾向與討論熱度
【報告架構】
**字數要求****800-1500字不含表格**
**嚴格遵守字數限制少於800字或超過1500字的報告將被退回**
**內容結構**
1. 情緒概要150字以上市場氛圍與情緒指標
2. 輿情分析400-450字主要討論議題與觀點分布
3. 關鍵洞察100字以上情緒極值或轉折訊號
4. 投資含義150字以上情緒面對操作策略的啟示
5. 情緒數據表格(必須)
**撰寫原則**
- **兼具專業與易懂**:使用專業術語的同時,請用生活化的語言讓一般投資人也能理解
- **舉例說明**在解讀情緒指標時適時加入白話文說明例如「恐慌貪婪指數達78就像溫度計顯示發燒代表市場過熱需要降溫」
- 客觀分析,避免主觀臆測
- 聚焦有價值的情緒訊號
- 必須包含情緒量化數據表格
**結尾提示**
請在報告最後加上以下結尾:
「---
💬 **本報告為市場情緒分析,建議搭配基本面及技術面綜合研判。投資有風險,請謹慎評估。**」
請提供專業且具洞察力、兼具易讀性的市場情緒分析報告。"""
+ """ 請務必在報告結尾附加一個 Markdown 表格,以整理報告中的要點。""",
)
prompt = ChatPromptTemplate.from_messages(
[
(
"system",
"您是一個樂於助人的人工智慧助理,與其他助理協同工作。"
" 使用提供的工具來逐步回答問題。"
" 如果您無法完全回答,沒關係;另一個擁有不同工具的助理會在您中斷的地方提供幫助。盡您所能取得進展。"
" 如果您或任何其他助理有最終交易提案:**買入/持有/賣出** 或可交付成果,"
" 請在您的回覆前加上「最終交易提案:**買入/持有/賣出**」,以便團隊知道停止。"
" 您可以使用以下工具:{tool_names}\n{system_message}"
"供您參考,目前日期是 {current_date}。我們目前要分析的公司是 {company_name} (股票代碼:{ticker}",
),
MessagesPlaceholder(variable_name="messages"),
]
)
prompt = prompt.partial(system_message=system_message)
prompt = prompt.partial(tool_names=", ".join([tool.name for tool in tools]))
prompt = prompt.partial(current_date=current_date)
prompt = prompt.partial(ticker=ticker)
prompt = prompt.partial(company_name=company_name)
chain = prompt | llm.bind_tools(tools)
result = chain.invoke(state["messages"])
# 報告邏輯修復只在LLM最終回應時保存報告
report = state.get("sentiment_report", "") # 保持現有報告
if len(result.tool_calls) == 0:
# 沒有工具調用,這是最終的分析報告
report = result.content
return {
"messages": [result],
"sentiment_report": report,
}
return social_media_analyst_node