76 lines
4.9 KiB
Python
76 lines
4.9 KiB
Python
import pandas as pd
|
||
from AgentProxy import AgentProxy
|
||
from datetime import datetime # Add this import
|
||
|
||
# Here you need to replace the API Key and API Secret with your,I provide a test key and secret here
|
||
api_key = '25bda2c39c0f8ca0'
|
||
api_secret = 'e0008b9b9727cb8ceea5a132dbe62495'
|
||
assistant_id = "66bb09a84673b57506fe7bbd"
|
||
agent = AgentProxy(assistant_id, api_key, api_secret)
|
||
|
||
|
||
sales_stages = ["Prospecting", "Evaluation", "Qualification", "Bidding / Negotiating", "Contract Review", "Closed Won", "Cancel", "Closed Lost"]
|
||
|
||
|
||
sales_stage_definition = '''
|
||
|
||
1. **Prospecting(潜在客户开发)**:这一阶段涉及识别和开发潜在客户。销售人员通过各种渠道(如电话、电子邮件、社交媒体等)寻找潜在买家。-阶段转化标准:①客户有需求 ②有明确的项目联系人;
|
||
|
||
2. **Evaluation(评估)**:在评估阶段,销售团队会评估潜在客户的需求,确定他们是否与公司的产品或服务相匹配。同时,潜在客户也在评估不同的供应商。-阶段转化标准:①客户有预算 ②有明确的项目时间 ③有预期的产品和数量
|
||
|
||
3. **Qualification(资格认定)**:这一阶段的目标是确定潜在客户是否具有成为合格销售机会的潜力。这通常涉及对客户的预算、需求、决策过程和时间线等进行评估。-阶段转化标准:①项目预算批准、项目已立项 ②有确定产品和数量;或③完成场景应用/技术适用性验证,客户确定平凯入围(完成poc)
|
||
|
||
4. **Bidding / Negotiating(投标/谈判)**:在这个阶段,销售人员会向客户提交正式的报价或提案,并进行必要的谈判,以达成最终的销售协议。-阶段转化标准:①完成可交付评审;②报价单通过审批;③投标结果确认赢标或完成商务谈判,确定价格和SOW,客户启动合同流程
|
||
|
||
5. **Contract Review(合同审查)**:一旦谈判完成,双方将审查合同条款,确保所有细节都得到妥善处理,并准备好签署。-阶段转化标准:完成飞书合同协商审批,确认合同条款(包括付款条件、服务开通时间等)
|
||
|
||
6. **Closed Won(成功关闭)**:这是销售流程的最终目标,表示交易已经成功完成,客户已经购买了产品或服务。-阶段转化标准:完成合同签署,合同归档
|
||
|
||
7. **Cancel(取消)**:在某些情况下,交易可能会在过程的任何阶段取消。这可能是因为客户改变了主意,或者发现产品或服务不再符合他们的需求。-阶段标准:①客户明确回复项目取消 ②客户明确表示没有预算 ③内部立项未通过
|
||
|
||
8. **Closed Lost(失败关闭)**:如果销售机会没有成功,它将被标记为“失败关闭”。这可能是因为竞争、价格问题或客户需求的改变等原因。-阶段转化标准:①投标确认结果未赢标 ②客户明确表示选择友商 ③poc结果客户确认平凯未入围/未通过 ④商务谈判失败 ⑤其他如商务关系没有竞争机会
|
||
上述每个阶段的阶段转化标准是准出标准,只有在满足该准出标准,才可以进入到下一个阶段
|
||
'''
|
||
|
||
abstract_actions = [
|
||
"客户接触与需求识别",
|
||
"产品演示与方案提供",
|
||
"商务谈判与合同准备",
|
||
"项目支持与优化",
|
||
"市场分析与策略调整",
|
||
"内部协调与支持",
|
||
"合同审查与订单处理",
|
||
"客户关系维护",
|
||
"后续跟进与机会挖掘"
|
||
]
|
||
|
||
# Read the Excel file
|
||
df = pd.read_excel('output_top200.xlsx')
|
||
|
||
# Iterate over each row in the DataFrame
|
||
for index, row in df.iterrows():
|
||
# Extract the information from the column "当前详细状态及Close节奏"
|
||
|
||
try:
|
||
detailed_status = row['当前详细状态及Close节奏']
|
||
print(f"Processing row {index} at current time: {datetime.now()}")
|
||
detailed_current_stage = row['Sales stage']
|
||
prompt = (f"某公司销售人员填写的销售动作日志为: {detailed_status} , "
|
||
f"销售动作可归类到如下抽象销售动作列表:{','.join(abstract_actions)},"
|
||
f"请分析销售动作日志,提取出销售动作,将销售动作按照上述抽象销售动作列表进行归类,同时分析该销售动作是否产生了行动结果以及如果有其行动结果是什么,并尝试将行动结果进行抽象化、概括化"
|
||
f"请按照如下格式输出分析结果:"
|
||
f"销售动作-销售动作归类-销售动作行动结果-抽象销售动作行动结果")
|
||
|
||
analysis_result = agent.send_message(prompt)
|
||
print(analysis_result)
|
||
df.at[index, '行动结果'] = analysis_result # Directly update the DataFrame
|
||
|
||
except Exception as e:
|
||
print(f"Error processing row {index}: {e}")
|
||
df.at[index, '行动结果'] = f"Error: {e}" # Log the error in the DataFrame
|
||
|
||
|
||
|
||
df.to_excel('analysis_result_action_result_top200.xlsx', index=False)
|
||
|