wecom-schedule
企业微信日程管理技能
wecom_mcp是一个 MCP tool,所有操作通过调用该 tool 完成。
⚠️ 前置条件:首次调用
wecom_mcp前,必须按wecom-preflight技能执行前置条件检查,确保工具已加入白名单。
通过 wecom_mcp call schedule <接口名> '<json入参>' 与企业微信日程系统交互。
注意事项
- 日程列表查询仅支持当日前后 30 天,时间格式
YYYY-MM-DD或YYYY-MM-DD HH:MM:SS - 涉及参与者 userid 时,需先使用 wecom-contact-lookup 技能获取;存在同名时展示候选让用户选择(禁止暴露 userid)
- 创建/修改/取消前,先确认目标日程和参与者信息
errcode != 0时展示错误信息;返回的start_time/end_time为 Unix 时间戳(秒),需转为可读格式- 注意时间格式转换:接口入参使用字符串格式(如
YYYY-MM-DD HH:MM:SS),但返回值多为 Unix 时间戳,使用时需进行格式转换
接口列表
get_schedule_list_by_range — 查询日程 ID 列表
使用 wecom_mcp tool 调用 wecom_mcp call schedule get_schedule_list_by_range '{"start_time": "YYYY-MM-DD HH:MM:SS", "end_time": "YYYY-MM-DD HH:MM:SS"}'
返回 schedule_id_list 数组。仅支持当日前后 30 天。
get_schedule_detail — 获取日程详情
使用 wecom_mcp tool 调用 wecom_mcp call schedule get_schedule_detail '{"schedule_id_list": ["SCHEDULE_ID_1", "SCHEDULE_ID_2"]}'
支持 1~50 个 ID,返回日程标题、时间、地点、参与者等。参见 API 详情。
create_schedule — 创建日程
使用 wecom_mcp tool 调用 wecom_mcp call schedule create_schedule '{"schedule": {"start_time": "YYYY-MM-DD HH:MM:SS", "end_time": "YYYY-MM-DD HH:MM:SS", "summary": "日程标题", "attendees": [{"userid": "USER_ID"}], "reminders": {"is_remind": 1, "remind_before_event_secs": 3600, "timezone": 8}}}'
参见 API 详情 | reminders 字段。
update_schedule — 修改日程
只需传入需修改的字段,未传字段保持不变。
使用 wecom_mcp tool 调用 wecom_mcp call schedule update_schedule '{"schedule": {"schedule_id": "SCHEDULE_ID", "summary": "更新后的标题"}}'
参见 API 详情。
cancel_schedule — 取消日程
使用 wecom_mcp tool 调用 wecom_mcp call schedule cancel_schedule '{"schedule_id": "SCHEDULE_ID"}'
add_schedule_attendees / del_schedule_attendees — 管理参与人
- 添加参与人:使用
wecom_mcptool 调用wecom_mcp call schedule add_schedule_attendees '{"schedule_id": "SCHEDULE_ID", "attendees": [{"userid": "USER_ID"}]}' - 移除参与人:使用
wecom_mcptool 调用wecom_mcp call schedule del_schedule_attendees '{"schedule_id": "SCHEDULE_ID", "attendees": [{"userid": "USER_ID"}]}'
check_availablity — 查询闲忙
使用 wecom_mcp tool 调用 wecom_mcp call schedule check_availablity '{"check_user_list": ["USER_ID_1", "USER_ID_2"], "start_time": "YYYY-MM-DD HH:MM:SS", "end_time": "YYYY-MM-DD HH:MM:SS"}'
支持 1~10 个用户,返回各用户的忙碌时段列表。参见 API 详情。
典型工作流
查询日程
经典 query 示例:
- "我今天有哪些日程?"
- "帮我看看这周三下午有没有会议"
- "明天的日程安排是什么?"
- "查一下最近有没有关于项目评审的日程"
- "我下周一到周五的日程都有哪些?"
流程:
- 根据用户意图计算时间范围(如"今天"→当日 00:00:00 至 23:59:59,"这周"→本周一至周日)
- 调用
get_schedule_list_by_range获取日程 ID 列表 - 调用
get_schedule_detail批量获取详情,将 Unix 时间戳转为可读时间 - 若用户提到关键词(如"项目评审"),在
summary中匹配筛选;未找到则逐步扩大范围至前后 30 天上限 - 展示日程列表时包含标题、时间、地点、参与者等关键信息,方便用户快速了解
创建日程
经典 query 示例:
- "帮我创建一个明天下午 2 点到 3 点的会议,标题叫需求评审"
- "安排一个周五全天的团建活动"
- "创建日程:后天上午 10 点和张三、李四开产品方案讨论会,地点在 3 楼会议室"
- "帮我建个日程,下周一 14:00-15:00,提前 15 分钟提醒"
- "约一个明天上午的日程,邀请王伟参加"
流程:
- 解析用户意图,提取时间、标题、地点、参与人、提醒设置等信息
- 若涉及参与人,先通过 wecom-contact-lookup 查询 userid;存在同名时展示候选让用户选择
- 若用户未指定提醒,默认设置提前 15 分钟提醒(
remind_before_event_secs: 900) - 若用户说"全天",设置
is_whole_day: 1,时间设为当天 00:00:00 至 23:59:59 - 向用户确认日程信息(标题、时间、地点、参与人等)后调用
create_schedule
修改日程
经典 query 示例:
- "把明天的需求评审改到后天下午 3 点"
- "帮我修改下今天下午的会议标题,改成技术方案评审"
- "我今天 14 点的日程地点改成线上腾讯会议"
- "把周五的团建活动推迟一个小时"
- "帮我给明天的周会加个描述:讨论 Q2 规划"
流程:
- 先通过查询工作流定位目标日程(根据用户提到的时间、标题等关键词匹配)
- 若匹配到多个日程,展示候选列表让用户确认
- 向用户确认要修改的字段和目标值
- 调用
update_schedule,只传入需修改的字段
取消日程
经典 query 示例:
- "取消明天下午的需求评审"
- "帮我把周五的团建日程删掉"
- "我不想开今天 15 点的会了,帮我取消"
流程:
- 先通过查询工作流定位目标日程
- 向用户确认取消的日程信息(标题、时间等),避免误操作
- 确认后调用
cancel_schedule
管理参与人
经典 query 示例:
- "把张三加到明天的需求评审会议里"
- "帮我把李四从周五的日程里移除"
- "明天下午的会议再邀请一下王伟和赵敏"
- "把我后天那个技术分享的参与人里去掉刘强"
流程:
- 通过 wecom-contact-lookup 获取目标人员 userid;存在同名时展示候选让用户选择
- 通过查询工作流定位目标日程
- 调用
add_schedule_attendees或del_schedule_attendees完成添加/移除
查询闲忙并安排会议
经典 query 示例:
- "帮我看看张三和李四明天下午有没有空"
- "查一下我和王伟这周的空闲时间,想约个会"
- "我想跟产品组的小明、小红开个会,看看大家什么时候有空"
- "找一个明天下午大家都有空的时段,安排一个 1 小时的会议"
流程:
- 通过 wecom-contact-lookup 获取相关人员 userid
- 调用
check_availablity查询指定时间范围内各用户的忙碌时段 - 分析所有用户的忙碌时段,计算出共同空闲时段并推荐给用户
- 用户确认时段后,调用
create_schedule创建会议并自动添加参与人