利用LangChain优化团队工作周报自动汇总:替代多智能体的可控解决方案

前段时间写了一篇关于使用CrewAI来实现的多智能体,来实现团队工作周报的汇总工作的案例,很多朋友反馈使用多智能体的过程中,智能体的"自由发挥"不太可控,导致生成的结果不稳定,甚至出现幻觉的情况,为了解决这个问题,我们今天来尝试一下单纯使用LangChain看看是否还有相同的问题,效果会不会好点。

步骤一:环境准备与需求分析

在开始编写脚本之前,我们需要确保开发环境已经准备就绪,并对需求进行详细分析。

环境准备

  • 确保Python环境已安装并配置好。
  • 安装必要的Python库,如email用于发送邮件,langchain用于处理文本等。
  • 确保有访问阿里企业邮箱SMTP服务的权限。

需求分析

  • 读取./docs目录下所有以.md格式存放的个人工作周报文件。
  • 汇总这些周报为一份团队工作周报。
  • 使用阿里企业邮箱将汇总的周报发送给领导。

步骤二:读取个人工作周报

首先,我们需要编写一个函数来读取每个员工的工作周报。我们将遍历./docs目录下的所有.md文件,并读取它们的内容。

python 复制代码
import os

def read_weekly_reports(directory):
    reports = {}
    for filename in os.listdir(directory):
        if filename.endswith('.md'):
            name = filename.split('.')[0]  # 假设文件名是"姓名 工作周报"
            with open(os.path.join(directory, filename), 'r', encoding='utf-8') as file:
                reports[name] = file.read()
    return reports

步骤三:汇总工作周报

接下来,我们需要将读取到的个人周报汇总成一份团队周报。我们将创建一个新的函数来完成这项任务。

python 复制代码
def summarize_reports(reports):
    summary = "团队工作周报:\n\n"
    all_str = ""
    for name, report in reports.items():
        all_str += f"{name}:\n{report}\n\n"
    # 初始化LLM
    llm = ChatOpenAI(openai_api_key=os.getenv("OPENAI_API_KEY"),model="gpt-3.5-turbo-0125")

    from langchain_core.prompts import ChatPromptTemplate
    prompt = ChatPromptTemplate.from_messages([
        ("system", "你是一个部门工作周报撰写者"),
        ("user", f"""
        请根据以下的个人工作周报内容,要求markdown格式,将个人周报合并,生成部门本周工作总结,生成的部门工作周报不包含人名:
        
        {all_str} """)
    ])
    from langchain_core.output_parsers import StrOutputParser
    
    output_parser = StrOutputParser()

    chain = prompt | llm | output_parser
    summary = chain.invoke({"input": all_str})

    return summary

步骤四:发送邮件

最后,我们需要编写一个函数来发送汇总好的团队周报。我们将使用Python的email库来实现邮件的发送。

python 复制代码
from email import EmailMessage

def send_email(summary):
    # 填写你的阿里企业邮箱SMTP配置信息
    sender = 'your_email@example.com'
    receiver = 'leader_email@example.com'
    subject = '团队工作周报'
    message = EmailMessage()
    message.set_content(summary)
    message['From'] = sender
    message['To'] = receiver
    message['Subject'] = subject

    # 这里需要使用你的邮箱SMTP服务器发送邮件
    # 请替换以下信息为你的SMTP服务器设置
    server = 'smtp.example.com'
    port = 465
    username = sender
    password = 'your_email_password'
    message.send(server, port, username, password)

步骤五:整合与测试

现在我们已经有了所有必要的函数,我们需要将它们整合到一个主函数中,并进行测试。

python 复制代码
def main():
    reports = read_weekly_reports(weekly_reports_dir)
    summary = summarize_reports(reports)
    send_email(summary)

if __name__ == "__main__":
    main()

在运行脚本之前,请确保你已经替换了所有的占位符,如邮箱地址、SMTP服务器设置等,为实际的配置信息。运行脚本后,检查是否有任何错误,并确保邮件已成功发送。

实际运行效果

可以看到,实际运行的效果还是非常不错的,相比多智能体来说可控的多了。

结论

多智能体比较适合有创造性的,比较复杂的,流程不单一的场景,可以给智能体一定的"自由发挥"的空间,而对于场景单一,流程相对固定的场景,只要提示词写的足够好,LangChain就可以满足需求了。

相关推荐
CoderJia程序员甲1 小时前
GitHub 热榜项目 - 日榜(2025-11-24)
ai·开源·llm·github·ai教程
合作小小程序员小小店10 小时前
web网页,在线%抖音,舆情,线性回归%分析系统demo,基于python+web+echart+nlp+线性回归,训练,数据库mysql
python·自然语言处理·回归·nlp·线性回归
mwq3012318 小时前
《前端项目技术文档生成器》Prompt(可复用模板)
前端·llm·visual studio code
大模型教程21 小时前
谷歌AI Agent技术指南深度解读,从概念到生产
langchain·llm·agent
大模型教程21 小时前
一张图拆解 AI Agent 的“五脏六腑”,从感知到进化的完整逻辑!
程序员·llm·agent
智泊AI21 小时前
预测也用上大模型了!时间序列预测是什么?
llm
AI大模型21 小时前
一文了解LLM应用架构:从Prompt到Multi-Agent
程序员·llm·agent
AI大模型21 小时前
LangChain、LangGraph、LangSmith这些AI开发框架有什么区别?一篇文章解释清楚
langchain·llm·agent
掘金詹姆斯1 天前
从 Dify 学 RAG 工程化:多格式文档解析的统一抽象设计
llm
吴佳浩1 天前
LangChain / LLM 开发中:invoke() 与 predict() 的区别
python·langchain·llm