sale_tools.py 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. from langchain.tools import tool
  2. from .base_tool import call_csharp_api, get_tool_prompt
  3. def get_sale_amt_default_config():
  4. """get_sale_amt 工具的默认配置"""
  5. return {
  6. "get_sale_amt": {
  7. "基础描述": "获取指定时间范围的销售金额,按月汇总",
  8. "入参说明": {
  9. "backend_url": "后端API地址",
  10. "token": "认证令牌",
  11. "funtion_name": "函数名称; get_sale_amt_by_month:按月汇总销售额; get_sale_amt_by_day:按天汇总销售额; get_sale_amt_by_produce:产品销售额; get_sale_amt_by_cus:客户销售额;get_sale_amt_by_saler:业务员销售额;get_sale_amt_by_cus_produce:客户产品销售额;get_hot_produce_not_buy:客户未购买过的热销产品",
  12. "cusname": "客户名称,只有get_hot_produce_not_buy需要",
  13. "firstdate": "开始日期,格式YYYY-MM-DD",
  14. "lastdate": "结束日期,格式YYYY-MM-DD 23:59:59",
  15. },
  16. "返回值说明": {
  17. "格式": "一个包含销售金额的字符串",
  18. },
  19. "输出格式要求": [
  20. "重复信息要总结归纳,精简显示",
  21. ],
  22. "使用示例": "用户输入:'查看2023年1月1日至2023年12月31日的销售金额' -> 获取2023年1月至12月的销售金额;'2024年前5热销产品是哪些?' -> 获取2024年产品销售额;'2025年前10销售额最高的客户是?' -> 获取2025年客户销售额';'客户A还没买过的热销型号有哪些?'->获取客户未买过近半年的热销款(没有指定时间范围默认近半年)",
  23. }
  24. }
  25. tool_description = get_tool_prompt("get_sale_amt", get_sale_amt_default_config())
  26. def get_sale_amt_func(
  27. backend_url: str,
  28. token: str,
  29. funtion_name: str,
  30. firstdate: str,
  31. lastdate: str,
  32. cusname: str = "",
  33. ) -> str:
  34. """实际的函数实现"""
  35. print(f"正在获取销售金额{funtion_name},时间范围:{firstdate} 至 {lastdate}")
  36. return call_csharp_api(
  37. backend_url,
  38. token,
  39. "sale_data_ai",
  40. funtion_name,
  41. {"arg_firstdate": firstdate, "arg_lastdate": lastdate, "arg_cusname": cusname},
  42. )
  43. get_sale_amt_func.__doc__ = tool_description
  44. get_sale_amt = tool(get_sale_amt_func)