Skip to content

Commit 8d4090a

Browse files
committed
docs: 增加 CONTRIBUTING.md,明确代码贡献和开发规范
1 parent 950a477 commit 8d4090a

5 files changed

Lines changed: 166 additions & 27 deletions

File tree

CONTRIBUTING.md

Lines changed: 124 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,124 @@
1+
# 🤝 参与贡献 (Contributing)
2+
3+
首先,非常感谢每一位愿意为 `jmcomic` 贡献代码和力量的机长!将 `jmcomic` 驶向更广阔的天空,离不开各位的添砖加瓦。
4+
5+
如果把每一次启动爬虫看作是一次狂热的航班起飞,那么这份文档就是塔台(仓库维护者)下发的**飞行手册与航权指南**。在改造战机、请求起飞之前,请务必花两分钟阅读这套协同规则。
6+
7+
## 💡 航前申报 (Before Writing Code)
8+
9+
如果你的航线规划(代码改动)涉及核心组件或者需要编写超过几行代码,**强烈建议你先通过提交一个 Issue 向塔台申请**,详细讨论你想要拓展的功能或重构的想法。
10+
11+
在投入大量燃油(精力)之前,我们应该先在技术路线和实现方式上达成一致,避免你的心血被白白浪费或航线规划不被塔台接受。
12+
13+
## 💻 登机准备与试飞 (Build and Test)
14+
15+
### 1. 组装战机 (Build)
16+
17+
参与贡献的第一步,是将本项目 **[Fork](https://github.com/hect0x7/JMComic-Crawler-Python/fork)** 到你个人的机库(GitHub 账号)下,然后克隆到控制台,并独立切出你的任务分支:
18+
19+
```bash
20+
git clone https://github.com/<your_user_name>/JMComic-Crawler-Python.git
21+
cd JMComic-Crawler-Python
22+
git checkout dev
23+
git checkout -b <your_feature_branch>
24+
```
25+
26+
强烈建议使用现代化的包管理器(如 [uv](https://github.com/astral-sh/uv))进行极速的沙盒隔离开发,避免污染你本地的系统空域:
27+
28+
```bash
29+
# 自动打通虚拟环境并注满燃油(安装源码及开发依赖)
30+
uv venv
31+
uv pip install -r requirements-dev.txt -e ./
32+
```
33+
34+
### 2. 空中改造 (Coding)
35+
36+
在战机组装完毕并建立好安全的沙盒后,你就可以开始编写代码进行你的改装了。
37+
38+
在动工之前,请务必仔细阅读本文档末尾的《[🛠️ 引擎改装规范(Coding Guidelines)](#%EF%B8%8F-引擎改装规范-coding-guidelines)》 部分。那里记载了你必须要遵守的架构底线(如统一日志与异常拆解机制)。这能确保你的航线设计不偏离塔台的预设轨迹,避免在安检时因为违规操作被打回。
39+
40+
### 3. 试飞运行 (Test)
41+
42+
向原仓库 `dev` 航道发起 PR 之前,你需要作为机长执行跑道级自检,**请务必保证你新编撰的代码能够顺利通过试飞用例**
43+
44+
你可以任选以下两种自检方式之一:
45+
46+
**选项 A:本地试飞 (终端测试)**
47+
本项目使用 Python 标准库 `unittest` 作为本地质检验证,跑通所有测试:
48+
```bash
49+
cd ./tests/
50+
uv run python -m unittest
51+
```
52+
53+
**选项 B:云端试飞 (GitHub Actions)**
54+
如果你的本地环境不便配置,也可以直接将代码推送至你个人 Fork 仓库的 `dev` 分支。云端塔台会在后台自动触发 `test_api.yml` 动作。
55+
> 💡 请前往你个人仓库的 **Actions** 面板,确保最新的推流全部亮起绿灯。
56+
57+
## 📥 申请接入航线 (Pull Request)
58+
59+
`jmcomic` 的代码管线有着极其明确的空域隔离,发起 PR 时请务必挂对你的目标分支:
60+
61+
- 🟢 **`dev` 航道 (代码开发)**:所有的**功能特性 (feat)****功能重构 (refactor)****Bug 修复 (fix)** 的 PR,均需指向原仓库的 `dev` 航道。由塔台(维护者)合并试飞后集中推向主发版链路。
62+
63+
- 📘 **`docs` 航道 (文档维护)**:本航道直通项目专属的 **[在线文档 (Read the Docs)](https://jmcomic.readthedocs.io/zh-cn/latest/)**。所有不涉及功能性代码修改的**纯粹文档更新**,请直接提交至此分支。入线后它将即刻触发并全网同步部署,绕过复杂的流水安检。需要注意的是,`docs` 航道的进度通常会超前于主系统 (`master`),塔台会在新版发布或定期检修时统一将二者对齐同步。
64+
65+
- 🚫 **禁飞区 (禁止直飞 master)**:为防止外部航班意外触发 `release_auto.yml` 这个威力巨大的自动发版工作流,**本项目不接受任何直接指向 `master` 分支的 PR**。所有的新功能与代码改造必须经由 `dev` 航道降落并完成试飞,新版本号的最终敲定与发布由塔台统一操控。
66+
67+
PR 申请后,我会尽快 review 各位机长的代码并反馈通讯。再次感谢你的付出!🎉
68+
69+
---
70+
71+
## 🛠️ 引擎改装规范 (Coding Guidelines)
72+
73+
> 📌 **塔台公告**:本《引擎改装规范》将伴随舰队的探索进度**持续迭代更新**。当前的强制适航指令主要聚焦于 **黑匣子 (日志记录)****空难溯源 (异常处理)** 两大核心电传模块。
74+
75+
### 📝 测试与操作手册 (Tests & Docs)
76+
77+
在完成代码改造后,机长请务必补全以下配套设施,这是确保新战机安全入库的必要纲领:
78+
79+
- **补充伴飞测试 (Tests)**:如果你打造了新型挂载(新功能)或排查掉了深层故障(Bug),你必须在 `tests/` 目录下为其编写对应的试飞用例。每一行核心代码都应当能通过稳定飞行测试。
80+
- **更新操作手册 (Docs)**:如果你实现了向其他机长开放的新仪表盘能力(功能入口),你还需要同步更新操作手册。文档应安放在 `assets/docs/` 下的对应位置。如果不知道该放哪,欢迎在 PR 中呼叫塔台。
81+
82+
---
83+
84+
### 💻 核心架构指令 (Architecture Rules)
85+
86+
在为 `jmcomic` 编写或改造代码时,请尽量增加类型注解 (Type hints) 并遵守合理的命名。除此之外,为确保全机队的统一性,请尽量遵循以下架构规范:
87+
88+
#### 1. 统一使用黑匣子网关 (统一日志)
89+
所有的业务代码请统一使用 `from jmcomic import jm_log` 进行留痕。**避免**直接 `import logging` 或手动去拼接带有 `【】` 的日志头:
90+
```python
91+
from jmcomic import jm_log
92+
93+
# ❌ 避免直接调用底层 logger
94+
jm_logger.info("【api】请求成功")
95+
96+
# ✅ 推荐做法,统一走网关,系统会自动套用格式化主题
97+
jm_log('api', '请求成功')
98+
```
99+
100+
#### 2. 优雅记录坠机日志 (异常处理)
101+
在飞行途中捕获到不可预料的 Exception 时,**无需**使用 `traceback.format_exc()` 费力拼装栈残骸。直接将异常对象作为入参传入 `jm_log` 即可,底层引擎会自动完整解析现场:
102+
```python
103+
try:
104+
do_something()
105+
except Exception as e:
106+
# ❌ 避免手动拼装残骸,否则日志过滤系统会把它当成纯文本
107+
import traceback
108+
jm_log('req.error', f'{e}\n{traceback.format_exc()}')
109+
110+
# ✅ 推荐做法:直接上交异常对象本体,清爽且精准
111+
jm_log('req.error', e)
112+
```
113+
114+
#### 3. 触发系统级警报 (统一抛错)
115+
当发生预期的业务级阻断时,请尽量避免直接抛出内置的裸 Exception。通过内置的 `ExceptionTool` 抛出,能确保异常准确传达给用户外部装配的监听器 (`ExceptionListener`):
116+
```python
117+
from jmcomic import ExceptionTool
118+
119+
# ❌ 避免直接 raise 底层异常,这会导致外部监听器失效
120+
raise Exception("解析 json 数据失败")
121+
122+
# ✅ 推荐做法:通过工具类附带上下文信息抛出
123+
ExceptionTool.raises_resp(msg="解析 json 数据失败", resp=response)
124+
```

README.md

Lines changed: 12 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -23,17 +23,17 @@
2323
</div>
2424

2525

26-
27-
2826
> 本项目封装了一套可用于爬取JM的Python API.
2927
>
3028
> 你可以通过简单的几行Python代码,实现下载JM上的本子到本地,并且是处理好的图片。
3129
>
30+
> **🧭 快速指路**
31+
> - [教程:使用 GitHub Actions 下载禁漫本子](./assets/docs/sources/tutorial/1_github_actions.md)
32+
> - [教程:导出并下载你的禁漫收藏夹数据](./assets/docs/sources/tutorial/10_export_favorites.md)
33+
> - [塔台广播:欢迎各位机长加入并贡献代码](./CONTRIBUTING.md)
34+
>
3235
> **友情提示:珍爱JM,为了减轻JM的服务器压力,请不要一次性爬取太多本子,西门🙏🙏🙏**.
33-
34-
[【指路】教程:使用GitHub Actions下载禁漫本子](./assets/docs/sources/tutorial/1_github_actions.md)
35-
36-
[【指路】教程:导出并下载你的禁漫收藏夹数据](./assets/docs/sources/tutorial/10_export_favorites.md)
36+
>
3737
3838

3939
![introduction.jpg](./assets/docs/sources/images/introduction.jpg)
@@ -59,7 +59,8 @@
5959

6060
## 安装教程
6161

62-
> ⚠如果你没有安装过Python,需要先安装Python再执行下面的步骤,且版本需要>=3.7([点我去python官网下载](https://www.python.org/downloads/)
62+
> ⚠如果你没有安装过 Python,需要先前往 [Python 官网下载](https://www.python.org/downloads/) 再执行以下步骤。
63+
>**推荐使用 Python 3.12及以上版本**
6364
6465
* 通过pip官方源安装(推荐,并且更新也是这个命令)
6566

@@ -201,8 +202,10 @@ jmcomic 123
201202

202203
## 使用小说明
203204

204-
* Python >= 3.7,建议3.9以上,因为jmcomic的依赖库可能会不支持3.9以下的版本。
205-
* 个人项目,文档和示例会有不及时之处,可以Issue提问
205+
* 推荐使用 **Python 3.12+**,目前最低兼容版本为3.9。
206+
> 注意:Python 3.9 及更早版本皆已于 2025 年彻底结束官方生命周期 (EOL),使用3.9及以下随时有可能遇到第三方库不兼容的问题。
207+
208+
* 个人项目,文档和示例会有不及时之处,可以Issue提问。
206209

207210
## 项目文件夹介绍
208211

assets/readme/README-en.md

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,13 @@
2929
>
3030
> With a few simple lines of Python code, you can download albums from JM to your local machine, with properly processed images.
3131
>
32+
> **🧭 Quick Guide**
33+
> - [Tutorial: Downloading JM Albums using GitHub Actions](../docs/sources/tutorial/1_github_actions.md)
34+
> - [Tutorial: Exporting and downloading your JM favorites data](../docs/sources/tutorial/10_export_favorites.md)
35+
> - [Tower Broadcast: Welcome captains to join and contribute code](../../CONTRIBUTING.md)
36+
>
3237
> **Friendly Prompt: Cherish JM. In order to reduce the pressure on JM servers, please do not download too many albums at once 🙏🙏🙏.**
3338
34-
[【Guide】Tutorial: Downloading JM Albums using GitHub Actions](../docs/sources/tutorial/1_github_actions.md)
35-
36-
[【Guide】Tutorial: Exporting and downloading your JM favorites data](../docs/sources/tutorial/10_export_favorites.md)
37-
3839

3940
![introduction.jpg](../docs/sources/images/introduction.jpg)
4041

@@ -59,7 +60,8 @@ In addition to downloading, other JM interfaces are also implemented on demand.
5960

6061
## Installation Guide
6162

62-
> ⚠ If you have not installed Python, you must install Python before executing the following steps. Version >= 3.7 is required ([Download from Python Official Site](https://www.python.org/downloads/)).
63+
> ⚠ If you have not installed Python, you must install Python before executing the following steps. [Download from Python Official Site](https://www.python.org/downloads/)
64+
> **Version 3.12+ is recommended.**
6365
6466
* Install via official pip source (recommended, the update command is identical)
6567

@@ -200,7 +202,9 @@ Please check the documentation homepage → [jmcomic.readthedocs.io (Chinese lan
200202

201203
## Prerequisites
202204

203-
* Python >= 3.7. Version 3.9+ is highly recommended because `jmcomic`'s dependencies may not perfectly support prior versions.
205+
* Version **3.12+** is recommended, with a minimum compatible version of 3.9.
206+
> Note: Python 3.9 and earlier versions reached their End Of Life (EOL) in 2025. You may encounter third-party library incompatibilities at any time if you use version 3.9 or below.
207+
204208
* Since this is a personal project, the documentation/examples may occasionally be out of sync. Please feel free to open an Issue for any clarifications.
205209

206210
## Directory Structure

assets/readme/README-jp.md

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,13 @@
2929
>
3030
> 数行のPythonコードだけで、JM上のアルバムをローカルへダウンロードすることができます。ダウンロードされた画像は完全に処理済みです。
3131
>
32+
> **🧭 クイックガイド**
33+
> - [チュートリアル: GitHub Actionsを使ってダウンロードする](../docs/sources/tutorial/1_github_actions.md)
34+
> - [チュートリアル: お気に入りのデータをエクスポートしてダウンロードする](../docs/sources/tutorial/10_export_favorites.md)
35+
> - [タワーブロードキャスト: 機長のみなさん、参加とコード提供を歓迎します](../../CONTRIBUTING.md)
36+
>
3237
> **ご案内:JMのサーバー負荷を軽減するため、一度に大量のダウンロードは控えてください 🙏🙏🙏**
3338
34-
[【ガイド】チュートリアル:GitHub Actionsを使ってダウンロードする](../docs/sources/tutorial/1_github_actions.md)
35-
36-
[【ガイド】チュートリアル:お気に入りのデータをエクスポートしてダウンロードする](../docs/sources/tutorial/10_export_favorites.md)
37-
3839

3940
![introduction.jpg](../docs/sources/images/introduction.jpg)
4041

@@ -59,7 +60,8 @@
5960

6061
## インストール手順
6162

62-
> ⚠ まだPythonをインストールしていない場合は、先にPythonのインストールをお願いします。要件: Python >= 3.7 ([公式のPythonページからダウンロード](https://www.python.org/downloads/))。
63+
> ⚠ まだPythonをインストールしていない場合は、先に [公式のPythonページからダウンロード](https://www.python.org/downloads/) してインストールをお願いします。
64+
> **Python 3.12以上の使用を推奨します**
6365
6466
* 公式 pip ソースからインストール(推奨。アップデートもこのコマンドを使用します)
6567

@@ -199,7 +201,9 @@ jmcomic 123
199201

200202
## ご利用上の注意点
201203

202-
* Python >= 3.7 ですが、jmcomicの依存ライブラリが古いバージョンをサポートしない可能性があるため、3.9以上をお勧めします。
204+
* **Python 3.12以上**を推奨します。現在の最小互換バージョンは3.9です。
205+
> 注意: Python 3.9 およびそれ以前のバージョンは2025年に完全にサポート終了 (EOL) となっており、3.9以下のバージョンを使用すると、サードパーティ製ライブラリの非互換性の問題がいつでも発生する可能性があります。
206+
203207
* 個人のプロジェクトであるため、ドキュメントやサンプルコードの更新が遅れることがあります。ご不明な点はIssueにてご質問ください。
204208

205209
## ディレクトリ構造のご紹介

assets/readme/README-kr.md

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,13 @@
2929
>
3030
> 몇 줄의 간단한 Python 코드만으로 JM의 앨범을 로컬로 원활하게 다운로드할 수 있으며, 이미지 또한 모두 처리된 상태입니다.
3131
>
32+
> **🧭 빠른 가이드**
33+
> - [튜토리얼: GitHub Actions를 사용하여 다운로드하기](../docs/sources/tutorial/1_github_actions.md)
34+
> - [튜토리얼: 즐겨찾기 데이터를 내보내고 다운로드하기](../docs/sources/tutorial/10_export_favorites.md)
35+
> - [타워 브로드캐스트: 기장 여러분의 소스 코드 기여와 동참을 환영합니다](../../CONTRIBUTING.md)
36+
>
3237
> **안내: JM 서버의 부하를 줄이기 위해 한 번에 너무 많은 앨범을 다운로드하지 말아주세요 🙏🙏🙏**
3338
34-
[【가이드】튜토리얼: GitHub Actions를 사용하여 다운로드하기](../docs/sources/tutorial/1_github_actions.md)
35-
36-
[【가이드】튜토리얼: 즐겨찾기 데이터를 내보내고 다운로드하기](../docs/sources/tutorial/10_export_favorites.md)
37-
3839

3940
![introduction.jpg](../docs/sources/images/introduction.jpg)
4041

@@ -59,7 +60,8 @@
5960

6061
## 설치 가이드
6162

62-
> ⚠ Python이 시스템에 설치되어 있지 않다면, 다음 단계를 진행하기 전에 반드시 Python을 먼저 설치해주시기 바랍니다. 필요 버전 >= 3.7 ([Python 공식 사이트에서 다운로드하기](https://www.python.org/downloads/)).
63+
> ⚠ Python이 시스템에 설치되어 있지 않다면, 다음 단계를 진행하기 전에 먼저 [Python 공식 사이트](https://www.python.org/downloads/) 에서 다운로드하여 설치해주시기 바랍니다.
64+
> **Python 3.12 이상 버전을 권장합니다**
6365
6466
* 공식 pip 저장소를 통한 설치 (추천. 업데이트 명령어도 동일합니다)
6567

@@ -199,7 +201,9 @@ jmcomic 123
199201

200202
## 사용 팁
201203

202-
* Python 3.7 이상을 요구하지만, 라이브러리와 jmcomic 패키지의 충돌을 막기 위해 3.9 이상의 쓰임을 추천합니다.
204+
* **Python 3.12 이상**을 권장하며, 현재 최소 호환 버전은 3.9입니다.
205+
> 참고: Python 3.9 및 이전 버전은 모두 2025년에 공식 지원 종료(EOL)되었으므로 3.9 이하 버전을 사용할 경우 언제든 서드파티 라이브러리 호환성 문제에 부딪힐 수 있습니다.
206+
203207
* 여유 시간에 만들어 지는 프로젝트이기에 정보나 활용 코드의 늦은 갱신이 다분합니다. 이슈(Issue)페이지로 연락주시기 바랍니다!
204208

205209
## 프로젝트 폴더 안내

0 commit comments

Comments
 (0)