Skip to main content

A CLI-downloader for site @kox.moe.

Reason this release was yanked:

此版本因上游服务器域名变更而完全失效。请升级到 v1.2.1 或更高版本。

Project description

Kmoe Manga Downloader

PyPI Downloads PyPI version Unit Tests Interpretor License

kmdr (Kmoe Manga Downloader) 是一个 Python 应用,用于从 Kmoe 网站下载漫画。它支持在终端环境下的登录、下载指定书籍及其卷,并支持回调脚本执行。

kmdr 使用演示

✨功能特性

  • 凭证管理: 命令行登录并持久化会话
  • 多种下载方式: 支持通过书籍 URL 或从收藏列表下载
  • 高效下载: 支持多线程、失败重试及断点续传
  • 配置持久化: 保存常用下载目录、代理等设置
  • 回调支持: 下载完成后自动执行自定义脚本

🛠️安装应用

你可以通过 PyPI 使用 pip 进行安装:

pip install kmoe-manga-downloader

📋使用方法

1. 登录 kmoe

首先需要登录 kox.moe 并保存登录状态(Cookie)。

kmdr login -u <your_username> -p <your_password>
# 或者
kmdr login -u <your_username>

第二种方式会在程序运行时获取登录密码,此时你输入的密码不会显示在终端中。

如果登录成功,会同时显示当前登录用户及配额。

2. 下载漫画书籍

你可以通过以下命令下载指定书籍或卷:

# 在当前目录下载第一、二、三卷
kmdr download --dest . --book-url https://kox.moe/c/50076.htm --volume 1,2,3
kmdr download -l https://kox.moe/c/50076.htm -v 1-3
# 在目标目录下载全部番外篇
kmdr download --dest path/to/destination --book-url https://kox.moe/c/50076.htm --vol-type extra -v all
kmdr download -d path/to/destination -l https://kox.moe/c/50076.htm -t extra -v all

常用参数说明:

  • -d, --dest: 下载的目标目录(默认为当前目录),在此基础上会额外添加一个为书籍名称的子目录
  • -l, --book-url: 指定书籍的主页地址
  • -v, --volume: 指定卷的名称,多个名称使用逗号分隔,all 表示下载所有卷
  • -t, --vol-type: 卷类型,vol: 单行本(默认);extra: 番外;seri: 连载话;all: 全部
  • -p, --proxy: 代理服务器地址
  • -r, --retry: 下载失败时的重试次数
  • -c, --callback: 下载完成后的回调脚本(使用方式详见 4. 回调函数
  • --num-workers: 最大同时下载数量,默认为 1

完整的参数说明可以从 help 指令中获取。

3. 查看账户状态

查看当前账户信息(账户名和配额等):

kmdr status

4. 回调函数

你可以设置一个回调函数,下载完成后执行。回调可以是任何你想要的命令:

kmdr download -d path/to/destination --book-url https://kox.moe/c/50076.htm -v 1-3 \
	--callback "echo '{b.name} {v.name} downloaded!' >> ~/kmdr.log"

字符串模板会直接朴素地替换,卷名或者书名可能会包含空格,推荐使用引号包含避免出现错误。

{b.name}, {v.name} 会被分别替换为书籍和卷的名称。常用参数:

变量名 描述
v.name 卷的名称
v.page 卷的页数
v.size 卷的文件大小
b.name 对应漫画的名字
b.author 对应漫画的作者

完整的可用参数请参考 structure.py 中关于 VolInfo 的定义。

5. 持久化配置

重复设置下载的代理服务器、目标路径等参数,可能会降低应用的使用效率。所以应用也提供了通用配置的持久化命令:

kmdr config --set proxy=http://localhost:7890 dest=/path/to/destination
kmdr config -s num_workers=5 "callback=echo '{b.name} {v.name} downloaded!' >> ~/kmdr.log"

只需要配置一次即可对之后的所有的下载指令生效。

注意:这里的参数名称不可以使用简写,例如 dest 不可用使用 d 来替换。

同时,你也可以使用以下命令进行持久化配置的管理:

  • -l, --list-option: 显示当前存在的各个配置
  • -s, --set: 设置持久化的配置,键和值通过 = 分隔,设置多个配置可以通过空格间隔
  • -c, --clear: 清除配置,all: 清除所有;cookie: 退出登录;option: 清除持久化的配置
  • -d, --delete, --unset: 清除单项配置

当前仅支持部分下载参数的持久化:num_workers, dest, retry, callback, proxy

⚠️ 声明

  • 本工具仅作学习、研究、交流使用,使用本工具的用户应自行承担风险
  • 作者不对使用本工具导致的任何损失、法律纠纷或其他后果负责
  • 作者不对用户使用本工具的行为负责,包括但不限于用户违反法律或任何第三方权益的行为

💬任何使用中遇到的问题、希望添加的功能,都欢迎提交 issue 交流!
⭐ 如果这个项目对你有帮助,请给它一个星标!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kmoe_manga_downloader-1.1.2.tar.gz (26.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kmoe_manga_downloader-1.1.2-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file kmoe_manga_downloader-1.1.2.tar.gz.

File metadata

  • Download URL: kmoe_manga_downloader-1.1.2.tar.gz
  • Upload date:
  • Size: 26.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kmoe_manga_downloader-1.1.2.tar.gz
Algorithm Hash digest
SHA256 cbb934b5a1b3921adb5a1d3539197be2b3fe40925b1fceff7b8fd87dc3f09567
MD5 b5826fe8d9c5e274c5c807651c41af80
BLAKE2b-256 f6aa83ddb98c97985d429c33a831cd77ee222d27cd55f49b06ac1d79580c476e

See more details on using hashes here.

Provenance

The following attestation bundles were made for kmoe_manga_downloader-1.1.2.tar.gz:

Publisher: release-package.yml on chrisis58/kmoe-manga-downloader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kmoe_manga_downloader-1.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for kmoe_manga_downloader-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 44e3b1bdc9a6378e5be31fe06a7030d2fe0b38c697ee4ce2428fdc9bc7ee69b1
MD5 717ba2fd919f993c429abd3c98e2c310
BLAKE2b-256 2263785421448ad87f036a1c35692a1a46b6f7d4b92af7714a5b07875880902a

See more details on using hashes here.

Provenance

The following attestation bundles were made for kmoe_manga_downloader-1.1.2-py3-none-any.whl:

Publisher: release-package.yml on chrisis58/kmoe-manga-downloader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page