Metadata-Version: 2.2
Name: nonebot_plugin_jmdownload
Version: 1.3.2
Summary: 基于NoneBot2的JM漫画下载插件
Home-page: https://github.com/QuickLAW/nonebot_plugin_JMDownload
Author: QuickLAW
Author-email: yewillwork@outlook.com
License: BSD 3-Clause License
Platform: all
Classifier: Development Status :: 4 - Beta
Classifier: Operating System :: OS Independent
Classifier: License :: OSI Approved :: BSD License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: nonebot2>=2.0.0rc1
Requires-Dist: nonebot-adapter-onebot>=2.0.0
Requires-Dist: jmcomic
Requires-Dist: PyYAML
Requires-Dist: Pillow
Requires-Dist: reportlab
Requires-Dist: psutil
Requires-Dist: PyPDF2
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: license
Dynamic: platform
Dynamic: requires-dist
Dynamic: summary

<div align="center">

# nonebot-plugin-JMDownload

_✨ NoneBot 插件简单描述 ✨_

<a href="./LICENSE">
    <img src="https://img.shields.io/github/license/QuickLAW/nonebot_plugin_JMDownload" alt="license">
</a>
<a href="https://pypi.org/project/nonebot-plugin-jmdownload/">
    <img src="https://img.shields.io/pypi/v/nonebot-plugin-jmdownload" alt="pypi">
</a>
<img src="https://img.shields.io/badge/python-3.8+-blue.svg" alt="python">
<img src="https://img.shields.io/badge/NoneBot-2.0.0rc1+-green.svg" alt="python">

</div>

✨ 基于 NoneBot2 的 JM 漫画下载插件，支持下载漫画并转换为 PDF 格式。本项目使用 DeepSeek 辅助完成编写，代码可能需要进一步优化。

## 📦 功能特点

- ✅ 支持通过序号下载 JM 漫画
- ✅ 自动将下载的图片转换为 PDF 格式
- ✅ 支持QQ群文件直接上传
- ✅ 完善的错误提示系统
- ✅ 自动清理临时文件

## 🛠️ 安装方法

### 前置要求
- 已安装 NoneBot 2.0 框架
- Python 3.8+ 环境

### 安装步骤

1. 安装必要依赖

```bash
pip install jmcomic -i https://pypi.org/project -U
```

2. 使用 pip 安装插件（推荐）

```bash
pip install nonebot-plugin-jmdownload
```

3. 手动安装（备选）
   - 下载本插件代码
   - 解压至 `plugins` 目录
   - 安装依赖 `pip install -r requirements.txt`

安装完成后，在 nonebot2 项目的 `pyproject.toml` 文件中添加插件名称：

```ini
plugins = ["nonebot_plugin_jmdownload"]
```

## ⚙️ 使用方法

### 基础配置

1. 在 NoneBot2 项目的 `.env` 文件中添加配置（未来移除此项的必须性）：

```plaintext
jm_config_path="data/nonebot_plugin_jmdownload/config.yml"
```

2. 首次运行时会自动生成配置文件，包含以下内容：

```yaml
# Github Actions 下载脚本配置
version: '1.0'

dir_rule:
  base_dir: data/nonebot_plugin_jmdownload/downloads  # 基础存储目录
  rule: Bd_Atitle_Pindex           # 目录命名规则

client:
  domain:
    - www.jmapiproxyxxx.vip
    - www.18comic-mygo.vip
    - 18comic-MHWs.CC
    - 18comic.vip
    - 18comic.org
  # 客户端实现类，可选：html(网页端)或api(APP端)
  impl: html
  # 请求失败重试次数
  retry_times: 5
  # 请求配置
  postman:
    meta_data:
      # 代理配置，可选值：
      # system - 使用系统代理
      # null - 不使用代理
      # clash/v2ray - 使用对应代理软件
      # 127.0.0.1:7890 - 直接指定代理地址
      # 或使用代理字典格式：
      # http: 127.0.0.1:7890
      # https: 127.0.0.1:7890
      proxies: system
      # cookies配置，用于需要登录的内容
      cookies: null

download:
  cache: true    # 文件存在时跳过下载
  image:
    decode: true  # 还原被混淆的图片
    suffix: .jpg  # 统一图片后缀格式
  threading:
    batch_count: 45  # 批量下载数量
```

更多配置选项请参考 [JMComic-Crawler-Python 项目文档](https://jmcomic.readthedocs.io/zh-cn/latest/option_file_syntax/)。

### 🚀 命令使用

```
/jm download <序号>
/jm 下载 <序号>
```

### ⚠️ 注意事项

1. 请确保机器人具有足够的存储空间
2. 下载完成后会自动清理临时文件
3. PDF 文件生成后会自动发送给用户

## ❓ 常见问题

Q: 下载失败怎么办？
A: 请检查网络连接和配置文件中的域名是否可用。

Q: 为什么下载速度很慢？
A: 目前需要获取所有图片后再进行转换，会造成阻塞并且导致下载速度较慢。

Q: 为什么转换 PDF 很慢？
A: 转换速度取决于图片数量和大小，请耐心等待。

## 📝 更新日志
### v1.3.2 (2025-03-28)
- 修复依赖问题

### v1.3.1 (2025-03-28)
- 添加损坏图片探测
- 优化内存处理功能，防止大文件转换时内存溢出
- 优化单核处理性能，提升PDF转换效率

### v1.3.0 (2025-03-26)
- 修复 PDF 转换问题
- 优化 PDF 转换速度

### v1.2.0 (2025-03-25)
- 下载使用异步
- 优化阻塞问题

### v1.0.0 (2025-03-25)
- 初始版本发布
- 支持基本的下载和 PDF 转换功能
- 添加自动清理功能
- 支持 QQ 群文件上传

## 🎯 开发计划

- [ ] 优化 PDF 转换速度
- [ ] 优化下载速度及阻塞问题
- [ ] 体验必须优化！
- [ ] 添加下载进度显示
- [ ] 支持批量下载功能

## 🤝 贡献指南

欢迎提交 Issue 和 Pull Request 来帮助改进这个项目。

## 📄 许可证

本项目采用 [BSD 3-Clause License](LICENSE) 开源许可证。

## 🙏 致谢

- [NoneBot2](https://github.com/nonebot/nonebot2)
- [PIL](https://python-pillow.org/)
- [jmcomic](https://github.com/hect0x7/JMComic-Crawler-Python)
- [image2pdf](https://github.com/salikx/image2pdf)

## ⚖️ 免责声明

本项目仅供学习交流使用，请勿用于非法用途。使用本项目所造成的任何后果由使用者自行承担。
