[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-70739":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":18,"stars90d":16,"forks30d":16,"starsTrendScore":19,"compositeScore":20,"rankGlobal":10,"rankLanguage":10,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":24,"hasPages":22,"topics":25,"createdAt":10,"pushedAt":10,"updatedAt":26,"readmeContent":27,"aiSummary":28,"trendingCount":16,"starSnapshotCount":16,"syncStatus":17,"lastSyncTime":29,"discoverSource":30},70739,"py12306","pjialin\u002Fpy12306","pjialin","🚂 12306 购票助手，支持集群，多账号，多任务购票以及 Web 页面管理 ","",null,"Python",14890,3590,320,187,0,2,3,6,45,"Apache License 2.0",false,"master",true,[],"2026-06-12 02:02:42","# 🚂 py12306 购票助手\n分布式，多账号，多任务购票\n\n## Features\n- [x] 多日期查询余票\n- [x] 自动打码下单\n- [x] 用户状态恢复\n- [x] 电话语音通知\n- [x] 多账号、多任务、多线程支持\n- [x] 单个任务多站点查询 \n- [x] 分布式运行\n- [x] Docker 支持\n- [x] 动态修改配置文件\n- [x] 邮件通知\n- [x] Web 管理页面\n- [x] 微信消息通知\n- [ ] 代理池支持 ([pyproxy-async](https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpyproxy-async))\n\n## 使用\npy12306 需要运行在 python 3.6 以上版本（其它版本暂未测试)\n\n**1. 安装依赖**\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpy12306\n\npip install -r requirements.txt\n```\n\n**2. 配置程序**\n```bash\ncp env.py.example env.py\n```\n自动打码\n\n（若快已停止服务，目前只能设置**free**打码模式）\nfree 已对接到打码共享平台，[https:\u002F\u002Fpy12306-helper.pjialin.com](https:\u002F\u002Fpy12306-helper.pjialin.com\u002F)，欢迎参与分享\n\n语音通知\n\n语音验证码使用的是阿里云 API 市场上的一个服务商，需要到 [https:\u002F\u002Fmarket.aliyun.com\u002Fproducts\u002F56928004\u002Fcmapi026600.html](https:\u002F\u002Fmarket.aliyun.com\u002Fproducts\u002F56928004\u002Fcmapi026600.html) 购买后将 appcode 填写到配置中\n\n**3. 启动前测试**\n\n目前提供了一些简单的测试，包括用户账号检测，乘客信息检测，车站检测等\n\n开始测试 -t \n```bash\npython main.py -t\n```\n\n测试通知消息 (语音, 邮件) -t -n\n```bash\n# 默认不会进行通知测试，要对通知进行测试需要加上 -n 参数 \npython main.py -t -n\n```\n\n**4. 运行程序**\n```bash\npython main.py\n```\n\n### 参数列表\n\n- -t 测试配置信息\n- -t -n 测试配置信息以及通知消息\n- -c 指定自定义配置文件位置\n\n### 分布式集群\n\n集群依赖于 redis，目前支持情况\n- 单台主节点多个子节点同时运行\n- 主节点宕机后自动切换提升子节点为主节点\n- 主节点恢复后自动恢复为真实主节点\n- 配置通过主节点同步到所有子节点\n- 主节点配置修改后无需重启子节点，支持自动更新\n- 子节点消息实时同步到主节点\n\n**使用**\n\n将配置文件的中 `CLUSTER_ENABLED` 打开即开启分布式\n\n目前提供了一个单独的子节点配置文件 `env.slave.py.example` 将文件修改为 `env.slave.py`， 通过 `python main.py -c env.slave.py` 即可快速启动\n\n\n## Docker 使用\n**1. 将配置文件下载到本地**\n```bash\ndocker run --rm pjialin\u002Fpy12306 cat \u002Fconfig\u002Fenv.py > env.py\n# 或\ncurl https:\u002F\u002Fraw.githubusercontent.com\u002Fpjialin\u002Fpy12306\u002Fmaster\u002Fenv.docker.py.example -o env.py\n```\n\n**2. 修改好配置后运行**\n```bash\ndocker run --rm --name py12306 -p 8008:8008 -d -v $(pwd):\u002Fconfig -v py12306:\u002Fdata pjialin\u002Fpy12306\n```\n当前目录会多一个 12306.log 的日志文件， `tail -f 12306.log`\n\n### Docker-compose 中使用\n**1. 复制配置文件**\n```\ncp docker-compose.yml.example docker-compose.yml\n```\n\n**2. 从 docker-compose 运行**\n\n在`docker-compose.yml`所在的目录使用命令\n```\ndocker-compose up -d\n```\n\n## Web 管理页面\n\n目前支持用户和任务以及实时日志查看，更多功能后续会不断加入\n\n**使用**\n\n打开 Web 功能需要将配置中的 `WEB_ENABLE` 打开，启动程序后访问当前主机地址 + 端口号 (默认 8008) 即可，如 http:\u002F\u002F127.0.0.1:8008\n\n## 更新\n- 19-01-10\n    - 支持分布式集群\n- 19-01-11\n    - 配置文件支持动态修改\n- 19-01-12\n    - 新增免费打码\n- 19-01-14\n    - 新增 Web 页面支持\n- 19-01-15\n    - 新增 钉钉通知\n    - 新增 Telegram 通知\n    - 新增 ServerChan 和 PushBear 微信推送\n- 19-01-18\n    - 新增 CDN 查询\n\n## 截图\n### Web 管理页面\n![Web 管理页面图片](https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpy12306\u002Fblob\u002Fmaster\u002Fdata\u002Fimages\u002Fweb.png)\n\n### 下单成功\n![下单成功图片](https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpy12306\u002Fblob\u002Fmaster\u002Fdata\u002Fimages\u002Forder_success.png)\n\n### 关于防封\n目前查询和登录操作是分开的，查询是不依赖用户是否登录，放在 A 云 T 云容易被限制 ip，建议在其它网络环境下运行\n\nQQ 交流群 [780289875](https:\u002F\u002Fjq.qq.com\u002F?_wv=1027&k=5PgzDwV)，TG 群 [Py12306 交流](https:\u002F\u002Ft.me\u002Fjoinchat\u002FF3sSegrF3x8KAmsd1mTu7w)\n\n### Online IDE\n[![在 Gitpod 中打开](https:\u002F\u002Fgitpod.io\u002Fbutton\u002Fopen-in-gitpod.svg)](https:\u002F\u002Fgitpod.io#https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpy12306)\n\n## Thanks\n- 感谢大佬 [testerSunshine](https:\u002F\u002Fgithub.com\u002FtesterSunshine\u002F12306)，借鉴了部分实现\n- 感谢所有提供 pr 的大佬 \n- 感谢大佬 [zhaipro](https:\u002F\u002Fgithub.com\u002Fzhaipro\u002Feasy12306) 的验证码本地识别模型与算法\n\n## License\n\n[Apache License.](https:\u002F\u002Fgithub.com\u002Fpjialin\u002Fpy12306\u002Fblob\u002Fmaster\u002FLICENSE)\n\n","py12306 是一个用于中国铁路12306网站的购票助手，支持多日期查询余票、自动打码下单、用户状态恢复等功能。项目采用Python编写，具备分布式运行能力，支持多账号和多任务购票，并提供Web页面管理功能。此外，它还集成了电话语音通知、邮件通知及微信消息推送等多种通知方式，以及Docker支持，便于部署与使用。适合需要高效、自动化处理火车票购买需求的个人或团队在高峰期抢票时使用。","2026-06-11 03:33:57","high_star"]