kmdr 是一个用于从 Kmoe 网站下载漫画的命令行工具。此 skill 教导如何使用 kmdr 完成漫画搜索、下载、账号管理等任务。
pip install --pre "kmoe-manga-downloader>=1.4.0.a1,<2.0.0"
验证安装:
kmdr --mode toolcall version
如果命令不存在,说明 kmdr 未安装或未添加到 PATH。
kmdr --mode toolcall status
code: 0 → 已登录,可继续操作
code: 21 或 code: 23 → 未登录或凭证失效,需配置凭证
方式一(推荐):用户自行登录
在终端中执行:
kmdr login -u <username> [-p <password>]
如果不提供 -p 参数,将交互式提示输入密码。凭证将安全存储在本地配置文件中,不会暴露给智能体。
方式二:智能体代为登录
如果用户确认当前环境安全,可提供用户名和密码,由智能体执行登录命令。
⚠️ 风险提示:凭证将出现在对话历史中,请确认环境安全后再选择此方式。
你的所有命令都应使用 --mode toolcall 参数以获取结构化的 JSON 输出:
kmdr --mode toolcall <command> [options]
值得注意的是,当你向用户建议手动执行命令时,不要包含 --mode toolcall 参数,以便用户使用默认的交互式的输出格式。
kmdr --mode toolcall [--fast-auth] search <keyword> [-p <page>] [-m]
: 搜索关键字(必需)
-p, --page: 页码,默认为 1
-m, --minimal: 仅返回书名和链接
使用场景:用户想要搜索特定漫画、查找某作者的作品、发现新漫画。
kmdr --mode toolcall [--fast-auth] download [options]
关键选项:
-l, --book-url : 漫画详情页 URL
-d, --dest : 下载保存路径,默认从配置中读取,如果没有配置则是当前目录
-v, --volume: 指定下载卷号(如 1,2,3 或 1-5 或 all)
-P, --use-pool: 启用凭证池自动故障转移
-b, --background: 后台下载,立即返回 task_id 和 PID,配合 progress 查询进度
--explain: 仅输出下载计划,不执行实际下载
使用场景:用户想要下载指定漫画、批量下载多个卷。推荐使用 --background 后台启动,用户可随时通过 progress 查询进度。
kmdr --mode toolcall login -u <username> -p <password>
kmdr --mode toolcall status
使用场景:用户需要登录账号、查看剩余配额。
kmdr --mode toolcall pool add -u <username> -p <password>
kmdr --mode toolcall pool list [--refresh]
kmdr --mode toolcall pool use <username>
kmdr --mode toolcall pool remove <username>
使用场景:用户需要管理多个账号、切换默认账号、查看所有账号配额。
kmdr --mode toolcall config --set <key>=<value>
kmdr --mode toolcall config --list
kmdr --mode toolcall config --clear
可配置项:dest, proxy, num_workers, retry, callback, format
使用场景:用户需要设置下载路径、配置代理、调整并发数。在更新配置后,请使用 config --list 验证更改是否生效。
详细输出格式请参阅 ./references/output-format.md。
{"type": "result", "code": 0, ...}: 最终结果
{"type": "progress", ...}: 进度更新(仅下载命令)
错误通过 code 字段表示,详细状态码请参阅 ./references/error-codes.md。
详细示例请参阅 ./assets/examples/ 目录。
kmdr --mode toolcall --fast-auth search "漫画名称"
url 字段
kmdr --mode toolcall --fast-auth download -l -v --explain
kmdr --mode toolcall --fast-auth download -l -v --background
progress 命令查询并报告
下载任务通常耗时 1-2 分钟(大批量下载可能更长),统一使用后台下载模式,这样可以跟踪进度并向用户报告。
先用 --explain 获取下载计划:
kmdr --mode toolcall --fast-auth download -l <url> -v <volume> --explain
返回信息包括:
estimate_quota_usage_mb: 预估配额消耗
avai_quota_mb: 当前可用配额
to_download: 待下载列表及各卷大小
skipped: 已存在文件列表
使用 --background 参数启动后台下载:
kmdr --mode toolcall --fast-auth download -l <url> -v <volume> --background
立即返回:
task_id: 任务 ID(如 20260415_143000)
pid: 后台下载进程的 PID
task_id 格式:YYYYMMDD_HHMMSS(时间戳),用于查询任务状态。
将 task_id 返回给用户。告知用户:"下载已启动,正在后台进行。您可以随时让我查询进度(例如'查询下载进度'或'查询进度
⚠️ task_id 是后续查询进度的唯一凭证。智能体必须在当前会话中牢记 task_id,以便用户后续发起查询时能直接使用,无需用户再次提供。
本步骤仅为用户主动询问时触发,无需智能体主动轮询。当用户提出"查询下载进度""下载完了吗"或类似请求时,使用 progress 命令:
kmdr --mode toolcall progress <task_id> --wait 15
⚠️ 重要:必须使用 --wait 参数,值至少为 15。--wait 的阻塞行为天然适配"用户提问 → 阻塞等待 → 立即回答"的交互模型。
参数:
: download --background 返回的任务 ID。如果智能体从上下文中找不到 task_id,可提醒用户提供
--wait: 阻塞等待时间(秒),至少 15
阻塞行为:
返回格式:统一返回 result 类型:
{"type": "result", "code": 0, "msg": "success", "data": {...}}
判断方式:通过 data.is_finished 判断任务状态:
is_finished: false → 任务进行中,检查 data.volumes 字段获取各卷进度,告知用户当前进度
is_finished: true → 任务完成,检查 data 字段获取最终结果(book、total、completed、failed、skipped)
当 progress 返回 is_finished: true 时:
data 字段中的结果:
book: 漫画名称
total: 总卷数
completed: 成功下载数
failed: 失败数
skipped: 跳过数
kmdr download -p -l -v
| 命令 | 用途 | 示例 |
|------|------|------|
| search | 搜索漫画 | kmdr --mode toolcall [--fast-auth] search "fate" |
| download --explain | 预估下载计划 | kmdr --mode toolcall [--fast-auth] download -l |
| download --background | 后台下载 | kmdr --mode toolcall [--fast-auth] download -l |
| progress | 查询后台任务进度 | kmdr --mode toolcall progress |
| login | 登录账号 | kmdr --mode toolcall login -u user -p pass |
| status | 查看配额 | kmdr --mode toolcall status |
| pool list | 列出凭证 | kmdr --mode toolcall pool list |
config | 配置设置 | kmdr --mode toolcall config --set dest=/downloads |
|---|
共 2 个版本