social-auto-upload 该项目旨在自动化发布视频到各个社交媒体平台
social-auto-upload This project aims to automate the posting of videos to various social media platforms.
-
中国主流社交媒体平台:
- 抖音
- 视频号
- bilibili
- 小红书
- 快手
-
部分国外社交媒体:
- tiktok
- youtube
- 易用版本(支持非开发人员使用):Gui or Cli
- API 封装
- Docker 部署
- 自动化上传(schedule)
- 定时上传(cron)
- cookie 管理
- 国外平台proxy 设置
- 多线程上传
- slack 推送
pip install -r requirements.txt
playwright install chromium firefox
非程序员,新手级教程
The project for my own project extracted, my release strategy is timed release (released a day in advance), so the release part of the event are used for the next day time!
If you need to release it immediately, you can study the source code or ask me questions.
该项目为我自用项目抽离出来,我的发布策略是定时发布(提前一天发布),故发布部分采用的事件均为第二天的时间
如果你有需求立即发布,可自行研究源码或者向我提问
filepath 本地视频目录,目录包含(filepath Local video directory containing)
- 视频文件(video files)
- 视频meta信息txt文件(video meta information txt file)
举例(for example):
file:2023-08-24_16-29-52 - 这位勇敢的男子为了心爱之人每天坚守 .mp4
meta_file:2023-08-24_16-29-52 - 这位勇敢的男子为了心爱之人每天坚守 .txt
meta_file 内容(content):
这位勇敢的男子为了心爱之人每天坚守 🥺❤️🩹
#坚持不懈 #爱情执着 #奋斗使者 #短视频
- 设置conf 文件中的
LOCAL_CHROME_PATH
(在douyin 或者视频号可能出现chromium 不兼容的各种问题,建议设置本地的chrome) - 这里分割出来3条路
- 可自行研究源码,免费、任意 穿插在自己的项目中
- 可参考下面的各个平台的使用指南,
examples
文件夹中有各种示例代码 - 使用cli 简易使用(支持tiktok douyin 视频号)
python cli_main.py <platform> <account_name> <action: upload, login> [options]
查看详细的参数说明使用:
python cli_main.py -h
usage: cli_main.py [-h] platform account_name action ...
Upload video to multiple social-media.
positional arguments:
platform Choose social-media platform: douyin tencent tiktok
account_name Account name for the platform: xiaoA
action Choose action
upload upload operation
login login operation
watch watch operation
options:
-h, --help show this help message and exit
示例
python cli_main.py douyin test login
douyin平台,账号名为test,动作为login
python cli_main.py douyin test upload "C:\Users\duperdog\Videos\2023-11-07_05-27-44 - 这位少女如梦中仙... .mp4" -pt 0
douyin平台, 账号名为test, 动作为upload, 视频文件(需对应的meta文件,详见上), 发布方式(pt):0 立即发布
python cli_main.py douyin test upload "C:\Users\superdog\Videos\2023-11-07_05-27-44 - 这位少女如梦中仙... .mp4" -pt 1 -t "2024-6-14 12:00"
douyin平台, 账号名为test, 动作为upload, 视频文件, 发布方式(pt):1 定时发布, 发布时间(t): 2024-6-14 12:00
使用playwright模拟浏览器行为
抖音前端实现,诸多css class id 均为随机数,故项目中locator多采用相对定位,而非固定定位
- 准备视频目录结构
- cookie获取:get_douyin_cookie.py 扫码登录
- 上传视频:upload_video_to_douyin.py
其他部分解释:
douyin_setup handle 参数为True,为手动获取cookie False 则是校验cookie有效性
generate_schedule_time_next_day 默认从第二天开始(此举为避免选择时间的意外错误)
参数解释:
- total_videos 本次上传视频个数
- videos_per_day 每日上传视频数量
- daily_times 视频发布时间 默认6、11、14、16、22点
- start_days 从第N天开始
2023年12月15日补充:使用chromium可能会出现无法识别视频封面图片的情况 解决方案:
- 下载chrome
- 找到chrome的安装目录
- 将目录配置到DouYinVideo类中 self.local_executable_path = "xxx/xxx/chrome.exe"
参考项目:
- https://github.com/wanghaisheng/tiktoka-studio-uploader
- https://github.com/Superheroff/douyin_uplod
- https://github.com/lishang520/DouYin-Auto-Upload.git
使用playwright模拟浏览器行为
- 准备视频目录结构
- cookie获取:get_tencent_cookie.py 扫码登录
- 上传视频:upload_video_to_tencent.py
其他部分解释:
参考上面douyin_setup 配置
视频号使用chromium会出现不支持上传视频,需要自行指定本地浏览器 解决方案:
- 下载chrome
- 找到chrome的安装目录
- 将目录配置到TencentVideo类中 self.local_executable_path = "xxx/xxx/chrome.exe"
该实现,借助ReaJason的xhs,再次感谢。
- 目录结构同上
- cookie获取,可使用chrome插件:EditThisCookie
- 黏贴至 accounts.ini文件中
xhs签名方式分为两种:
- 本地签名 sign_locl (默认)
- 自建签名服务 sign
测试下来发现本地签名,在实际多账号情况下会存在问题
故如果你有多账号分发,建议采用自建签名服务(todo 上传docker配置)
遇到签名问题,可尝试更新 "utils/stealth.min.js"文件 https://github.com/requireCool/stealth.min.js
24.4.10 大多数人小红书失败的原因在于你的cookie有问题,请参照你cookie是不是如我这样
关于xhs部分可参考作者: https://reajason.github.io/xhs/basic
- 扫码登录方式(实验下来发现与浏览器获取的存在区别,会有问题,未来再研究)
参考项目:
该实现,借助biliup的biliup-rs,再次感谢。
bilibili cookie 长期有效(至少我运行2年以来是这样的)
其他平台 诸如linux mac 服务器运行 请自行研究
参考项目:
使用playwright模拟浏览器行为(Simulating Browser Behavior with playwright)
- 准备视频目录结构(Prepare the video directory structure)
- cookie获取(generate your cookie):get_tk_cookie.py
- 上传视频(upload video):upload_video_to_tiktok.py
其他部分解释:
参考上面douyin_setup 配置
other part explain(for eng friends):
tiktok_setup handle parameter is True to get cookie manually False to check cookie validity
generate_schedule_time_next_day defaults to start on the next day (this is to avoid accidental time selection errors)
Parameter explanation:
- total_videos Number of videos uploaded this time
- videos_per_day Number of videos uploaded per day
- daily_times The video posting times are 6, 11, 14, 16, 22 by default.
- start_days Starts on the nth day.
参考项目:
整理后上传
- https://github.com/KLordy/auto_publish_videos
- db支持
- 定期自动发布
- cookie db管理
- 视频去重
- 消息推送
如果你也是一个人
,喜欢折腾
, 想要在如此恶劣的大环境寻找突破
希望探索 #技术变现 #AI创业 #跨境航海 #自动化上传 #自动化视频 #技术探讨
可以来群里和大家交流
后台回复 上传 加群交流 |
如果你觉得有用 |
如果这个项目对你有帮助,⭐以表示支持