File size: 10,436 Bytes
175da6d 302c2cc d4388d2 b843170 a4b06cd 302c2cc 655f61f 6a4a4bc f748362 655f61f 34d738a 98a6584 34d738a 302c2cc 655f61f 454a5e0 655f61f 92c4933 655f61f a8a1183 ac5fd86 a8a1183 b1f092b a8a1183 c9ac367 5e2212b c9ac367 a8a1183 454a5e0 c9ac367 454a5e0 655f61f c9ac367 655f61f f748362 175da6d 655f61f 302c2cc 655f61f 24382f9 fbc0b71 ac5fd86 fbc0b71 ac5fd86 fbc0b71 ac5fd86 fbc0b71 a4b06cd ac5fd86 fbc0b71 b843170 655f61f b843170 655f61f 650e8da 655f61f 95edc20 655f61f ae24926 655f61f ae24926 655f61f ae24926 655f61f cabac22 655f61f cabac22 655f61f cabac22 2c40478 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 | ---
title: social-auto-upload
emoji: 📤
colorFrom: blue
colorTo: green
sdk: docker
app_port: 5409
---
# social-auto-upload
`social-auto-upload` 是一个强大的自动化工具,旨在帮助内容创作者和运营者高效地将视频内容一键发布到多个国内外主流社交媒体平台。
项目实现了对 `抖音`、`Bilibili`、`小红书`、`快手`、`视频号`、`百家号` 以及 `TikTok` 等平台的视频上传、定时发布等功能。
结合各平台 `uploader` 模块,您可以轻松配置和扩展支持的平台,并通过示例脚本快速上手。
<img src="media/show/tkupload.gif" alt="tiktok show" width="800"/>
## 目录
- [💡 功能特性](#💡功能特性)
- [🚀 支持的平台](#🚀支持的平台)
- [💾 安装指南](#💾安装指南)
- [🏁 快速开始](#🏁快速开始)
- [🐇 项目背景](#🐇项目背景)
- [📃 详细文档](#📃详细文档)
- [🐾 交流与支持](#🐾交流与支持)
- [🤝 贡献指南](#🤝贡献指南)
- [📜 许可证](#📜许可证)
- [⭐ Star History](#⭐Star-History)
## 💡功能特性
### 已支持平台
- **国内平台**:
- [x] 抖音
- [x] 视频号
- [x] Bilibili
- [x] 小红书
- [x] 快手
- [x] 百家号
- **国外平台**:
- [x] TikTok
### 核心功能
- [x] 定时上传 (Cron Job / Scheduled Upload)
- [ ] Cookie 管理 (部分实现,持续优化中)
- [ ] 国外平台 Proxy 设置 (部分实现)
### 计划支持与开发中
- **平台扩展**:
- [ ] YouTube
- **功能增强**:
- [x] 更易用的版本 (GUI / CLI 交互优化)
- [x] API 封装
- [x] Docker 部署
- [ ] 自动化上传 (更智能的调度策略)
- [ ] 多线程/异步上传优化
- [ ] Slack/消息推送通知
### 2025.10.30目前现状
该项目本人很长一段时间没维护了,有比较大的问题也是能简单快速修复就修复掉
因为我自己也在创业,每天时间都用不完
目前问题主要集中在
1. 小红书部分,这部分是直接适用xhs这个库来实现的
2. web 端(vue版本),这个版本是群友LeeDebug他帮忙做的(再次感谢他)
因为我日常也在用,我用的不是web端,而是最初`uploader`文件夹里的版本,也就是文档里提到的部分https://sap-doc.nasdaddy.com/
所以这里一般遇到的问题,我都会尝试去解决,一并推送到该仓库
目前能遇到的问题,基本上都比较小,可能是元素变化导致的
在初期设计的时候,其实我已经参考了某些不可变元素去选择,极大的避免了后期因为平台页面修改导致的元素变化
该项目不仅仅是技术人员,有不少是非技术的从业人员,他们是没能力修复一个简单弱小的bug
为了能帮助更多的人,所以呼吁**技术小伙伴**
如果大家
- 修复了一些bug
- 增加一些对大家有帮助的功能
请积极的提出pr,我会想尽可能的确认后合并的,在此感谢大家对于开源项目的支持,帮助更多的人
我自己也会尽100%的力量,在自己项目稳定后,修bug,加更多的平台,开发出gradio版本(更易部署),大家谅解
---
## 🚀支持的平台
本项目通过各平台对应的 `uploader` 模块实现视频上传功能。您可以在 `examples` 目录下找到各个平台的使用示例脚本。
每个示例脚本展示了如何配置和调用相应的 uploader。
## 💾安装指南
1. **克隆项目**:
```bash
git clone https://github.com/dreammis/social-auto-upload.git
cd social-auto-upload
```
2. **安装依赖**:
建议在虚拟环境中安装依赖。
```bash
conda create -n social-auto-upload python=3.10
conda activate social-auto-upload
# 挂载清华镜像 or 命令行代理
pip install -r requirements.txt
```
3. **安装 Playwright 浏览器驱动**:
```bash
playwright install chromium firefox
```
根据您的需求,至少需要安装 `chromium`。`firefox` 主要用于 TikTok 上传(旧版)。
4. **修改配置文件**:
复制 `conf.example.py` 并重命名为 `conf.py`。
在 `conf.py` 中,您需要配置以下内容:
- `LOCAL_CHROME_PATH`: 本地 Chrome 浏览器的路径,比如 `C:\Program Files\Google\Chrome\Application\chrome.exe` 保存。
**临时解决方案**
需要在根目录创建 `cookiesFile` 和 `videoFile` 两个文件夹,分别是 存储cookie文件 和 存储上传文件 的文件夹
5. **配置数据库**:
如果 db/database.db 文件不存在,您可以运行以下命令来初始化数据库:
```bash
cd db
python createTable.py
```
此命令将初始化 SQLite 数据库。
6. **启动后端项目**:
```bash
python sau_backend.py
```
后端项目将在 `http://localhost:5409` 启动。
7. **启动前端项目**:
```bash
cd sau_frontend
npm install
npm run dev
```
前端项目将在 `http://localhost:5173` 启动,在浏览器中打开此链接即可访问。
> 非程序员用户可以参考:[新手级教程](https://juejin.cn/post/7372114027840208911)
## 🏁快速开始
1. **准备 Cookie**:
大多数平台需要登录后的 Cookie 信息才能进行操作。请参照 examples 目录下各 `get_xxx_cookie.py` 脚本(例如 get_douyin_cookie.py, get_ks_cookie.py)的说明,运行脚本以生成并保存 Cookie 文件(通常在 `cookies/[PLATFORM]_uploader/account.json`)。
2. **准备视频文件**:
将需要上传的视频文件(通常为 `.mp4` 格式)放置在 videos 目录下。
部分平台支持视频封面,可以将封面图片(例如 `.png` 格式,与视频同名)也放在此目录。
如果需要上传标题及标签,请在视频文件旁边创建一个同名的 `.txt` 文件,内容为标题和标签,以换行分隔。
3. **修改并运行示例脚本**:
打开 examples 目录中您想使用的平台的上传脚本(例如 upload_video_to_douyin.py)。
- 根据脚本内的注释和说明,确认 Cookie 文件路径、视频文件路径等配置是否正确。
- 您可以修改脚本以适应您的具体需求,例如批量上传、自定义标题、标签等。
4. **执行上传**:
运行修改后的示例脚本,例如:
```bash
python examples/upload_video_to_douyin.py
```
## Docker 环境
### 自己构建镜像
1. **构建Docker镜像**:
```
docker build -t social-auto-upload:latest .
```
2. **运行Docker容器**:
```
docker run -d -it -p 5409:5409 social-auto-upload:latest
```
### 使用预构建镜像
1. **拉取镜像**:
```
docker pull gzxy/social-auto-upload:latest
```
2. **运行Docker容器**:
```
docker run -d -it -p 5409:5409 gzxy/social-auto-upload:latest
```
启动容器后访问:[http://localhost:5409](http://localhost:5409)
### Hugging Face Spaces
仓库已配置 Docker Space 元数据(`README.md` 顶部 YAML)与端口环境变量。部署步骤与可见性说明见 [docs/deploy-huggingface.md](docs/deploy-huggingface.md)。
## 🐇项目背景
该项目最初是我个人用于自动化管理社交媒体视频发布的工具。我的主要发布策略是提前一天设置定时发布,因此项目中很多定时发布相关的逻辑是基于“第二天”的时间进行计算的。
如果您需要立即发布或其他定制化的发布策略,欢迎研究源码或在社区提问。
## 📃详细文档
更详细的文档和说明,请查看:[social-auto-upload 官方文档](https://sap-doc.nasdaddy.com/)
## 🐾交流与支持
[☕ Donate as u like](https://www.buymeacoffee.com/hysn2001m) - 如果您觉得这个项目对您有帮助,可以考虑赞助。
如果您也是独立开发者、技术爱好者,对 #技术变现 #AI创业 #跨境电商 #自动化工具 #视频创作 等话题感兴趣,欢迎加入社群交流。
### Creator
<table>
<td align="center">
<a href="https://sap-doc.nasdaddy.com/">
<img src="media/mp.jpg" width="200px" alt="NasDaddy公众号"/>
<br />
<sub><b>微信公众号</b></sub>
</a>
<br />
<a href="https://github.com/dreammis/social-auto-upload/commits?author=dreammis" title="Code">💻</a>
<br />
关注公众号,后台回复 `上传` 获取加群方式
</td>
<td align="center">
<a href="https://sap-doc.nasdaddy.com/">
<img src="media/QR.png" width="200px" alt="赞赏码/入群引导"/>
<br />
<sub><b>交流群 (通过公众号获取)</b></sub>
</a>
<br />
<a href="https://sap-doc.nasdaddy.com/" title="Documentation">📖</a>
<br />
如果您觉得项目有用,可以考虑打赏支持一下
</td>
</table>
### Active Core Team
<table>
<td align="center">
<a href="https://leedebug.github.io/">
<img src="media/edan-qrcode.png" width="200px" alt="Edan Lee"/>
<br />
<sub><b>Edan Lee</b></sub>
</a>
<br />
<a href="https://github.com/dreammis/social-auto-upload/commits?author=LeeDebug" title="Code">💻</a>
<a href="https://leedebug.github.io/" title="Documentation">📖</a>
<br />
封装了 api 接口和 web 前端管理界面
<br />
(请注明来意:进群、学习、企业咨询等)
</td>
</table>
## 🤝贡献指南
欢迎各种形式的贡献,包括但不限于:
- 提交 Bug报告 和 Feature请求。
- 改进代码、文档。
- 分享使用经验和教程。
如果您希望贡献代码,请遵循以下步骤:
1. Fork 本仓库。
2. 创建一个新的分支 (`git checkout -b feature/YourFeature` 或 `bugfix/YourBugfix`)。
3. 提交您的更改 (`git commit -m 'Add some feature'`)。
4. Push到您的分支 (`git push origin feature/YourFeature`)。
5. 创建一个 Pull Request。
## 📜许可证
本项目暂时采用 [MIT License](LICENSE) 开源许可证。
## ⭐Star-History
> 如果这个项目对您有帮助,请给一个 ⭐ Star 以表示支持!
[](https://star-history.com/#dreammis/social-auto-upload&Date)
|