A CLI-downloader for site @kox.moe.
Reason this release was yanked:
此版本因上游服务器域名变更而完全失效。请升级到 v1.2.1 或更高版本。
Project description
Kmoe Manga Downloader
kmdr (Kmoe Manga Downloader) 是一个 Python 脚本,用于从 Kmoe 网站下载漫画。它支持在终端环境下的登录、下载指定书籍及其卷,并支持回调脚本执行。
✨功能特性
- 以命令行参数登录网站并持久化凭证
- 支持多种方式筛选需要的内容
- 支持网站上提供的不同的下载方式
- 支持多线程下载,失败重试、断点续传
- 提供自定义的下载完成回调命令
- 提供通用配置持久化的实现
🛠️安装依赖
在使用本脚本之前,请确保你已经安装了项目所需要的依赖:
git clone https://github.com/chrisis58/kmoe-manga-downloader.git
cd kmoe-manga-downloader
pip install -r requirements.txt
📋使用方法
1. 登录 kmoe
首先需要登录 kox.moe 并保存登录状态(Cookie)。
python kmdr.py login -u <your_username> -p <your_password>
或者:
python kmdr.py login -u <your_username>
第二种方式会在程序运行时获取登录密码。如果登录成功,会同时显示当前登录用户及配额。
2. 下载漫画书籍
你可以通过以下命令下载指定书籍或卷:
# 在 path/to/destination 目录下载第一、二、三卷
python kmdr.py download -d path/to/destination --book-url https://kox.moe/c/50076.htm --volume 1,2,3
python kmdr.py download -d path/to/destination --book-url https://kox.moe/c/50076.htm -v 1-3
# 在 path/to/download/destination 目录下载全部番外篇
python kmdr.py download -d path/to/destination --book-url https://kox.moe/c/50076.htm --vol-type 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. 查看账户状态
查看当前账户信息(例如:账户名和配额等):
python kmdr.py status
4. 回调函数
你可以设置一个回调函数,下载完成后执行。回调可以是任何你想要的命令:
python kmdr.py 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. 持久化配置
重复设置下载的代理服务器、目标路径等参数,可能会降低脚本的使用效率。所以脚本也提供了通用配置的持久化命令:
python kmdr.py config --set proxy=http://localhost:7890 dest=/path/to/destination
python kmdr.py 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
⚠️ 声明
- 本工具仅作学习、研究、交流使用,使用本工具的用户应自行承担风险
- 作者不对使用本工具导致的任何损失、法律纠纷或其他后果负责
- 作者不对用户使用本工具的行为负责,包括但不限于用户违反法律或任何第三方权益的行为
⭐ 如果这个项目对你有帮助,请给它一个星标!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kmoe_manga_downloader-1.0.0.tar.gz.
File metadata
- Download URL: kmoe_manga_downloader-1.0.0.tar.gz
- Upload date:
- Size: 24.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ae541342272d3ad134884ea3e04dbcd523238017b39af9ffff25e80a6546b6bf
|
|
| MD5 |
9704542ab6cf1e1cb13bac99f912873b
|
|
| BLAKE2b-256 |
7add529ae8af1ee1f7e6c8dafa83b5306216f8eda8a9b3b85a8f9eeb3d0f032a
|
Provenance
The following attestation bundles were made for kmoe_manga_downloader-1.0.0.tar.gz:
Publisher:
release-package.yml on chrisis58/kmoe-manga-downloader
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kmoe_manga_downloader-1.0.0.tar.gz -
Subject digest:
ae541342272d3ad134884ea3e04dbcd523238017b39af9ffff25e80a6546b6bf - Sigstore transparency entry: 397674659
- Sigstore integration time:
-
Permalink:
chrisis58/kmoe-manga-downloader@2b9d303a05e900b7bf30e824b22a6997cb94d128 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/chrisis58
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-package.yml@2b9d303a05e900b7bf30e824b22a6997cb94d128 -
Trigger Event:
release
-
Statement type:
File details
Details for the file kmoe_manga_downloader-1.0.0-py3-none-any.whl.
File metadata
- Download URL: kmoe_manga_downloader-1.0.0-py3-none-any.whl
- Upload date:
- Size: 27.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3013588e537eec516f8991ea3eb6e77f064aaff094c5ad86e4a5eedc6fd9fc30
|
|
| MD5 |
762179750336c61f972196fbbb07f82b
|
|
| BLAKE2b-256 |
2e00299d688f77bd4f46beaf4a8ac30415778263cb44e34182025edb94393727
|
Provenance
The following attestation bundles were made for kmoe_manga_downloader-1.0.0-py3-none-any.whl:
Publisher:
release-package.yml on chrisis58/kmoe-manga-downloader
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kmoe_manga_downloader-1.0.0-py3-none-any.whl -
Subject digest:
3013588e537eec516f8991ea3eb6e77f064aaff094c5ad86e4a5eedc6fd9fc30 - Sigstore transparency entry: 397674672
- Sigstore integration time:
-
Permalink:
chrisis58/kmoe-manga-downloader@2b9d303a05e900b7bf30e824b22a6997cb94d128 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/chrisis58
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-package.yml@2b9d303a05e900b7bf30e824b22a6997cb94d128 -
Trigger Event:
release
-
Statement type: