wecomcli-edit-todo

企业微信待办事项编辑技能,支持创建、更新、删除待办及变更用户处理进度状态。在用户说"帮我创建一个待办"、"把这个任务分派给张三"、"标记待办完成"、"删掉那个待办"、"帮我建个提醒"、"更新一下待办内容"、"把提醒时间改到下周"、"接受这个待办"、"拒绝这个待办"等需要对待办进行写操作的场景时使用。

1,354 stars

Best use case

wecomcli-edit-todo is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

企业微信待办事项编辑技能,支持创建、更新、删除待办及变更用户处理进度状态。在用户说"帮我创建一个待办"、"把这个任务分派给张三"、"标记待办完成"、"删掉那个待办"、"帮我建个提醒"、"更新一下待办内容"、"把提醒时间改到下周"、"接受这个待办"、"拒绝这个待办"等需要对待办进行写操作的场景时使用。

Teams using wecomcli-edit-todo should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/wecomcli-edit-todo/SKILL.md --create-dirs "https://raw.githubusercontent.com/WecomTeam/wecom-cli/main/skills/wecomcli-edit-todo/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/wecomcli-edit-todo/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How wecomcli-edit-todo Compares

Feature / Agentwecomcli-edit-todoStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

企业微信待办事项编辑技能,支持创建、更新、删除待办及变更用户处理进度状态。在用户说"帮我创建一个待办"、"把这个任务分派给张三"、"标记待办完成"、"删掉那个待办"、"帮我建个提醒"、"更新一下待办内容"、"把提醒时间改到下周"、"接受这个待办"、"拒绝这个待办"等需要对待办进行写操作的场景时使用。

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

SKILL.md Source

# 企业微信待办事项编辑技能

> `wecom-cli` 是企业微信提供的命令行程序,所有操作通过执行 `wecom-cli` 命令完成。

通过 `wecom-cli` 对企业微信待办事项进行写操作,支持四种操作:创建待办、更新待办、删除待办、变更用户状态。

## 行为策略

**重试策略**: 遭遇"返回 HTTP 错误"或"HTTP 请求失败"时,主动重试,最多重试三次。

---

## 操作

### 1. 创建待办

创建一个新的待办事项,可指定内容、分派人和提醒时间:

```bash
wecom-cli todo create_todo '<json格式的入参>'
```

**参数说明:**

需要遵循 “注意事项”中的格式要求:

| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| `content` | string | ✅ | 待办内容 |
| `follower_list` | object | ❌ | 分派人列表,格式见注意事项第 7 条 |
| `remind_time` | string | ❌ | 提醒时间,格式:`YYYY-MM-DD HH:mm:ss` |


**调用示例:**

```bash
wecom-cli todo create_todo '{"content": "<待办的内容>", "remind_time": "2025-06-01 09:00:00"}'
```

**返回格式:**

```json
{
    "errcode": 0,
    "errmsg": "ok",
    "todo_id": "TODO_ID"
}
```

---

### 2. 更新待办

修改已有待办事项的内容、分派人、状态或提醒时间:

```bash
wecom-cli todo update_todo '<json格式的入参>'
```

**参数说明:**

需要遵循 “注意事项”中的格式要求:

| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| `todo_id` | string | ✅ | 待办 ID |
| `content` | string | ❌ | 新的待办内容 |
| `follower_list` | object | ❌ | 新的分派人列表(全量替换,非追加),格式见注意事项第 7 条。若要新增分派人,需先查出现有分派人,合并后一起提交 |
| `todo_status` | number | ❌ | 新的待办状态:`0`-已完成,`1`-进行中。删除请使用 `delete_todo` |
| `remind_time` | string | ❌ | 新的提醒时间 |

**调用示例:**

```bash
wecom-cli todo update_todo '{"todo_id": "TODO_ID", "content": "<待办的内容>", "remind_time": "2025-07-01 09:00:00"}'
```

**返回格式:**

```json
{
    "errcode": 0,
    "errmsg": "ok"
}
```

---

### 3. 删除待办

删除指定的待办事项:

```bash
wecom-cli todo delete_todo '<json格式的入参>'
```

**参数说明:**

需要遵循 “注意事项”中的格式要求:

| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| `todo_id` | string | ✅ | 待办 ID |

**调用示例:**

```bash
wecom-cli todo delete_todo '{"todo_id": "TODO_ID"}'
```

**返回格式:**

```json
{
    "errcode": 0,
    "errmsg": "ok"
}
```

> 删除操作不可撤销,执行前应向用户确认。
> 注意:`delete_todo` 与 `update_todo` 设置 `todo_status=2` 效果相同,优先使用 `delete_todo`。

---

### 4. 变更用户待办状态

更改当前用户在某个待办中的状态(拒绝/接受/已完成):

```bash
wecom-cli todo change_todo_user_status '<json格式的入参>'
```

**参数说明:**

需要遵循 “注意事项”中的格式要求:

| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| `todo_id` | string | ✅ | 待办 ID |
| `user_status` | number | ✅ | 用户状态:`0`-拒绝,`1`-接受,`2`-已完成 |

**调用示例:**

```bash
wecom-cli todo change_todo_user_status '{"todo_id": "TODO_ID", "user_status": 2}'
```

**返回格式:**

```json
{
    "errcode": 0,
    "errmsg": "ok"
}
```

---

## 典型工作流

### 创建待办并分派给同事

用户问:"帮我创建一个待办,让张三下周一前完成需求文档"

1. 第一步:通过 wecomcli-lookup-contact 技能查询张三的 userid,在返回结果中筛选姓名为"张三"的成员,获取其 userid
2. 第二步:创建待办并分派:`wecom-cli todo create_todo '{"content": "<待办的内容>", "follower_list": {"followers": [{"follower_id": "zhangsan", "follower_status": 1}]}, "remind_time": "2025-03-24 09:00:00"}'`

> `follower_id` 必须来自 `wecomcli-lookup-contact` 技能的 `get_userlist` 接口返回的 `userid`,禁止自行猜测。若搜索结果有多个同名人员,需展示候选列表让用户确认。

### 标记待办完成

需要区分两种场景:**标记待办本身完成**(改 `todo_status`)和**标记我的参与状态为完成**(改 `user_status`)。

#### 场景 A:标记待办本身完成

用户问:"把'完成Q2规划文档'这个待办标记为完成" / "关闭这个待办"

1. 第一步:通过 wecomcli-get-todo-list 获取待办列表,找到目标待办的 todo_id:`wecom-cli todo get_todo_list '{}'`
2. 第二步:通过 wecomcli-get-todo-detail 获取详情,确认是目标待办:`wecom-cli todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
3. 第三步:确认后,将待办状态改为已完成:`wecom-cli todo update_todo '{"todo_id": "TODO_ID", "todo_status": 0}'`

#### 场景 B:标记我的参与状态为完成

用户问:"我已经完成了这个待办" / "标记我的部分为完成"

1. 第一步:通过 wecomcli-get-todo-list 获取待办列表,找到目标待办的 todo_id:`wecom-cli todo get_todo_list '{}'`
2. 第二步:通过 wecomcli-get-todo-detail 获取详情,确认是目标待办:`wecom-cli todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
3. 第三步:确认后,变更当前用户的参与状态为已完成:`wecom-cli todo change_todo_user_status '{"todo_id": "TODO_ID", "user_status": 2}'`

> **如何判断用户意图:** 如果用户说"标记完成"且该待办是自己创建的、没有其他分派人,通常指场景 A(标记待办本身完成)。如果该待办有多个参与人,用户可能只是想标记自己那部分完成(场景 B)。不确定时应向用户确认。

> 用户提供的是待办内容描述而非 ID,所以需要先通过 wecomcli-get-todo-list 和 wecomcli-get-todo-detail 查找再匹配。匹配到多个相似待办时,列出候选项让用户确认。

### 更新待办内容或提醒时间

用户问:"把那个需求文档的待办提醒时间改到下周五"

1. 第一步:查找目标待办:`wecom-cli todo get_todo_list '{}'`,再查详情:`wecom-cli todo get_todo_detail '{"todo_id_list": ["TODO_ID_1", "TODO_ID_2"]}'`
2. 第二步:确认目标后更新:`wecom-cli todo update_todo '{"todo_id": "TODO_ID", "remind_time": "2025-03-28 09:00:00"}'`

### 删除待办

用户问:"删掉'代码评审'那个待办"

1. 第一步:查找目标待办:`wecom-cli todo get_todo_list '{}'`,再查详情:`wecom-cli todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
2. 第二步:向用户确认后删除:`wecom-cli todo delete_todo '{"todo_id": "TODO_ID"}'`

> 删除前必须向用户确认,确认措辞示例:"确认删除待办'代码评审'吗?删除后不可恢复。"

---

## 注意事项

1. **todo_id 来源规则**
   - `todo_id` 必须来自 `wecomcli-get-todo-list` 返回的结果,禁止自行推测或构造
   - 用户通常提供待办内容描述而非 ID,应先通过 wecomcli-get-todo-list 查列表再匹配
   - 若匹配到多个相似待办,展示候选列表让用户确认

2. **follower_id 来源规则**
   - `follower_id` 即 `userid`,必须通过 `wecomcli-lookup-contact` 技能的 `get_userlist` 接口获取
   - 禁止根据用户姓名自行猜测 userid
   - 若搜索结果有多个同名人员,展示候选列表让用户选择

3. **时间格式**
   - 所有时间参数使用 `YYYY-MM-DD HH:mm:ss` 格式
   - 用户说"明天"、"下周一"等相对时间时,根据当前日期推算具体日期

4. **状态值含义**
   - 待办状态(`todo_status`):`0`-已完成,`1`-进行中,`2`-已删除
   - 用户状态(`user_status`):`0`-拒绝,`1`-接受,`2`-已完成
   - 分派人状态(`follower_status`):`0`-拒绝,`1`-接受,`2`-已完成

5. **破坏性操作确认**
   - 删除待办(`delete_todo`)前必须向用户确认
   - 变更状态为"拒绝"(`user_status=0`)前建议向用户确认

6. **错误处理**
   - 若 `errcode` 不为 `0`,说明接口调用失败,告知用户 `errmsg` 中的错误信息

7. **follower_list** 的格式(作为输入参数的时候)

    ```json
    "follower_list": {                    // 分派人列表
        "followers": [                    // 注意里面还有一层是 "followers",它的value才是真正的列表数组
            {
                "follower_id": "FOLLOWER_ID",      // 分派人id
                "follower_status": 1              // 分派人状态:0-拒绝, 1-接受, 2-已完成
            }
        ]
    }
    ```
    > `follower_id` 即 userid,需要通过 `wecomcli-lookup-contact` 查询获取,禁止自行猜测或构造。

## 相关技能

- **获取待办列表**:`wecomcli-get-todo-list` — 查询待办概要列表,获取 todo_id
- **获取待办详情**:`wecomcli-get-todo-detail` — 根据 todo_id 获取完整内容
- **通讯录查询**:`wecomcli-lookup-contact` 的 `get_userlist` — 获取成员 userid,用于 `follower_id`

Related Skills

wecomcli-todo

1387
from WecomTeam/wecom-cli

企业微信待办事项管理技能,支持查询待办列表、获取待办详情、创建待办、更新待办、删除待办及变更用户处理进度状态。在用户说"看看我的待办列表"、"我有哪些待办"、"帮我创建一个待办"、"把这个任务分派给张三"、"标记待办完成"、"删掉那个待办"、"帮我建个提醒"、"更新一下待办内容"、"把提醒时间改到下周"、"接受这个待办"、"拒绝这个待办"、"这个待办的详情"、"待办分派给谁了"等需要对待办进行读写操作的场景时使用。

wecomcli-schedule

1387
from WecomTeam/wecom-cli

企业微信日程管理技能。适用于用户对企业微信日程的各类管理需求。当用户需要:(1) 查询指定时间范围内的日程列表或获取日程详细信息(标题、时间、地点、参与者等),(2) 创建新日程并设置提醒、参与人等,(3) 修改已有日程的标题、时间、地点等信息或取消日程,(4) 添加或移除日程参与人,(5) 查询多个成员的闲忙状态并分析共同空闲时段以安排会议时使用此技能。

wecomcli-msg

1387
from WecomTeam/wecom-cli

企业微信消息技能。提供会话列表查询、消息记录拉取(支持文本/图片/文件/语音/视频)、多媒体文件获取和文本消息发送能力。当用户需要"查看消息"、"看聊天记录"、"发消息给某人"、"最近有什么消息"、"给群里发消息"、"看看发了什么图片/文件"时触发。

wecomcli-meeting

1387
from WecomTeam/wecom-cli

企业微信会议技能,支持创建预约会议、查询会议列表、获取会议详情、取消会议、更新会议成员。当用户需要"创建会议"、"预约会议"、"约会议"、"安排会议"、"查看会议"、"查询会议列表"、"会议详情"、"什么时候开会"、"有哪些会议"、"查找会议"、"取消会议"、"删除会议"、"修改会议成员"、"添加会议参与人"、"移除会议成员"时触发。

wecomcli-doc

1387
from WecomTeam/wecom-cli

企业微信文档与智能表格管理技能。提供文档的创建、读取、编辑能力,以及智能表格的结构管理(子表、字段)和数据管理(记录增删改查)。适用场景:(1) 以 Markdown 格式获取文档完整内容 (2) 新建文档或智能表格 (3) 用 Markdown 格式覆写文档内容 (4) 管理智能表格子表和字段/列 (5) 查询、添加、更新、删除智能表格记录。支持通过 docid 或文档 URL 定位文档。

wecomcli-contact

1387
from WecomTeam/wecom-cli

通讯录成员查询技能,获取当前用户可见范围内的通讯录成员,支持按姓名/别名本地筛选匹配。返回 userid、姓名和别名。⚠️ 仅返回当前用户有权限查看的成员,非全量成员。

wecomcli-manage-smartsheet-schema

1354
from WecomTeam/wecom-cli

企业微信智能表格结构管理技能。提供子表(Sheet)和字段(Field/列)的增删改查能力。适用场景:(1) 查询智能表格的子表列表 (2) 添加、更新、删除子表 (3) 查询子表的字段/列信息 (4) 添加、更新、删除字段/列。当用户需要管理智能表格的表结构、列定义、子表配置时触发此 Skill。支持通过 docid 或文档 URL 定位文档。

wecomcli-manage-smartsheet-data

1354
from WecomTeam/wecom-cli

企业微信智能表格数据(记录)管理技能。提供智能表格记录的增删改查能力。适用场景:(1) 查询子表全部记录 (2) 添加一行或多行记录 (3) 更新已有记录 (4) 删除记录。当用户需要读取表格数据、写入新数据、修改或删除表格行时触发此 Skill。支持通过 docid 或文档 URL 定位文档。

wecomcli-manage-schedule

1354
from WecomTeam/wecom-cli

企业微信日程管理技能。适用于用户对企业微信日程的各类管理需求。当用户需要:(1) 查询指定时间范围内的日程列表或获取日程详细信息(标题、时间、地点、参与者等),(2) 创建新日程并设置提醒、参与人等,(3) 修改已有日程的标题、时间、地点等信息或取消日程,(4) 添加或移除日程参与人,(5) 查询多个成员的闲忙状态并分析共同空闲时段以安排会议时使用此技能。

wecomcli-manage-doc

1354
from WecomTeam/wecom-cli

企业微信文档管理技能。提供文档的创建、读取和编辑能力,支持通过 docid 或文档 URL 操作企业微信文档(doc_type=3)和智能表格(doc_type=10)。适用场景:(1) 以 Markdown 格式导出获取文档完整内容(异步轮询) (2) 新建文档或智能表格 (3) 用 Markdown 格式覆写文档内容。当用户需要查看文档内容、创建新文档、编辑文档正文时触发此 Skill。

wecomcli-lookup-contact

1354
from WecomTeam/wecom-cli

通讯录成员查询技能,获取当前用户可见范围内的通讯录成员,支持按姓名/别名本地筛选匹配。返回 userid、姓名和别名。⚠️ 仅返回当前用户有权限查看的成员,非全量成员。

wecomcli-get-todo-list

1354
from WecomTeam/wecom-cli

企业微信待办列表查询技能,支持按创建时间和提醒时间过滤,支持分页。在用户说"看看我的待办列表"、"我有哪些待办"、"这周的待办有哪些"、"最近有什么待办"、"查一下我的待办"、"列出所有待办"等需要浏览待办概览的场景时使用。注意:此技能仅返回待办概要信息(不含内容和分派人),如需完整详情请配合 wecomcli-get-todo-detail 使用。