快手(KuaiShou)无水印视频/图片下载工具
📑 项目功能
✅ 下载快手无水印作品文件
☑️ 下载快手作品封面图片
☑️ 下载快手作品音乐文件
✅ 自动跳过已下载的作品文件
✅ 作品文件完整性处理机制
✅ 持久化储存作品信息至文件
✅ 记录已下载作品 ID
✅ 支持文件断点续传下载
✅ 作品文件储存至单独文件夹
✅ 自定义作品文件名称格式
✅ 从浏览器读取 Cookie
✅ 支持设置作者别名
✅ 按作者归档保存作品
✅ 自动更新作者昵称
✅ 支持 API 调用功能
☑️ 后台监听剪贴板下载作品
📸 程序截图
前往 bilibili 观看演示;前往 YouTube 观看演示
🥣 使用方法
🖱 程序运行
⭐ Mac OS、Windows 10 及以上用户可前往 Releases 或者 Actions 下载程序压缩包,解压后打开程序文件夹,双击运行 main
即可使用!
⭐ 本项目包含自动构建可执行文件的 GitHub Actions,使用者可以随时使用 GitHub Actions 将最新源码构建为可执行文件!
⭐ 自动构建可执行文件教程请查阅本文档的 构建可执行文件指南
部分;如果需要更加详细的图文教程,请 查阅文章!
注意:Mac OS 平台可执行文件 main
可能需要从终端命令行启动;受设备限制,Mac OS 平台可执行文件尚未经过测试,无法保证可用性!
若通过此方式使用程序,文件默认下载路径为:.\_internal\Volume\Download
;配置文件路径为:.\_internal\Volume\config.yaml
程序更新
方案一:下载并解压文件,将旧版本的 _internal\Volume
文件夹复制到新版本的 _internal
文件夹。
方案二:下载并解压文件(不要运行程序),复制全部文件,直接覆盖旧版本文件。
⌨️ 源码运行
安装版本号为
3.12
的 Python 解释器下载本项目最新的源码或 Releases 发布的源码至本地
打开终端,切换至项目根路径
运行
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt
命令安装程序所需模块运行
main.py
即可使用
⌨️ Docker 运行
获取镜像
方式一:使用
Dockerfile
文件构建镜像方式二:使用
docker pull joeanamier/ks-downloader
命令拉取镜像方式三:使用
docker pull ghcr.io/joeanamier/ks-downloader
命令拉取镜像
创建容器
TUI 模式:
docker run --name 容器名称(可选) -p 主机端口号:5557 -v ks_downloader_volume:/app/Volume -it <镜像名称>
API 模式:
docker run --name 容器名称(可选) -p 主机端口号:5557 -v ks_downloader_volume:/app/Volume -it <镜像名称> python main.py api
注意:此处的<镜像名称>
需与您在第一步中使用的镜像名称保持一致(joeanamier/ks-downloader
或ghcr.io/joeanamier/ks-downloader
)
运行容器
启动容器:
docker start -i 容器名称/容器 ID
重启容器:
docker restart -i 容器名称/容器 ID
Docker 运行项目时不支持 从浏览器读取 Cookie,无法使用 监听剪贴板 功能,可以正常粘贴内容,其他功能如有异常请反馈!
🖥 服务器模式
启动:运行命令:python .\main.py api
关闭:按下 Ctrl
+ C
关闭服务器
访问 http://127.0.0.1:5557/docs
或者 http://127.0.0.1:5557/redoc
;你会看到自动生成的交互式 API 文档!
🔗 支持链接
https://www.kuaishou.com/f/分享码
https://v.kuaishou.com/分享码
https://www.kuaishou.com/short-video/作品ID
https://kuaishou.cn/short-video/作品ID
https://live.kuaishou.com/u/作者ID/作品ID
推荐使用分享链接;支持单次输入多个作品链接,链接之间使用空格分隔。
🪟 关于终端
⭐ 推荐使用 Windows 终端 (Windows 11 默认终端)运行程序以便获得最佳显示效果!
📜 其他说明
Windows 系统需要以管理员身份运行程序才能读取 Chromium、Chrome、Edge 浏览器 Cookie
如果开启保存作品数据至文件功能,作品数据默认储存至
./Volume/Data/DetailData.db
文件程序设置、下载记录数据储存至
./Volume/KS-Downloader.db
文件项目内置请求延时机制,以避免请求频率过快,代码位置:
./source/tools/sleep.py
⚙️ 配置文件
项目根目录下的 config.yaml
文件,首次运行自动生成,可以自定义部分运行参数。
如果项目功能无法正常使用,请尝试配置 Cookie 后再使用!
如果 author_archive
参数设置为 true
,程序会把每个作者的作品储存至单独的文件夹;当作者的昵称发生变化时,程序会自动更新已下载作品文件名称中的作者昵称部分!
除此之外,你还可以通过设置 mapping_data
参数为某个作者设置别名;如果对某个作者设置了别名,程序会使用你设置的作者别名去替代作者昵称!
📦 构建可执行文件指南
本指南将引导您通过 Fork 本仓库并执行 GitHub Actions 自动完成基于最新源码的程序构建和打包!
使用步骤
1. Fork 本仓库
点击项目仓库右上角的 Fork 按钮,将本仓库 Fork 到您的个人 GitHub 账户中
您的 Fork 仓库地址将类似于:
https://github.com/your-username/this-repo
2. 启用 GitHub Actions
前往您 Fork 的仓库页面
点击顶部的 Settings 选项卡
点击右侧的 Actions 选项卡
点击 General 选项
在 Actions permissions 下,选择 Allow all actions and reusable workflows 选项,点击 Save 按钮
3. 手动触发打包流程
在您 Fork 的仓库中,点击顶部的 Actions 选项卡
找到名为 构建可执行文件 的工作流
点击右侧的 Run workflow 按钮:
选择 master 或者 develop 分支
点击 Run workflow
4. 查看打包进度
在 Actions 页面中,您可以看到触发的工作流运行记录
点击运行记录,查看详细的日志以了解打包进度和状态
5. 下载打包结果
打包完成后,进入对应的运行记录页面
在页面底部的 Artifacts 部分,您将看到打包的结果文件
点击下载并保存到本地,即可获得打包好的程序
注意事项
资源使用:
Actions 的运行环境由 GitHub 免费提供,普通用户每月有一定的免费使用额度(2000 分钟)
代码修改:
您可以自由修改 Fork 仓库中的代码以定制程序打包流程
修改后重新触发打包流程,您将得到自定义的构建版本
与主仓库保持同步:
如果主仓库更新了代码或工作流,建议您定期同步 Fork 仓库以获取最新功能和修复
Actions 常见问题
Q1: 为什么我无法触发工作流?
A: 请确认您已按照步骤 启用 Actions,否则 GitHub 会禁止运行工作流
Q2: 打包流程失败怎么办?
A:
检查运行日志,了解失败原因
确保代码没有语法错误或依赖问题
如果问题仍未解决,可以在本仓库的 Issues 页面 提出问题
Q3: 我可以直接使用主仓库的 Actions 吗?
A: 由于权限限制,您无法直接触发主仓库的 Actions。请通过 Fork 仓库的方式执行打包流程
⚠️ 免责声明
使用者对本项目的使用由使用者自行决定,并自行承担风险。作者对使用者使用本项目所产生的任何损失、责任、或风险概不负责。
本项目的作者提供的代码和功能是基于现有知识和技术的开发成果。作者按现有技术水平努力确保代码的正确性和安全性,但不保证代码完全没有错误或缺陷。
本项目依赖的所有第三方库、插件或服务各自遵循其原始开源或商业许可,使用者需自行查阅并遵守相应协议,作者不对第三方组件的稳定性、安全性及合规性承担任何责任。
使用者在使用本项目时必须严格遵守 GNU General Public License v3.0 的要求,并在适当的地方注明使用了 GNU General Public License v3.0 的代码。
使用者在使用本项目的代码和功能时,必须自行研究相关法律法规,并确保其使用行为合法合规。任何因违反法律法规而导致的法律责任和风险,均由使用者自行承担。
使用者不得使用本工具从事任何侵犯知识产权的行为,包括但不限于未经授权下载、传播受版权保护的内容,开发者不参与、不支持、不认可任何非法内容的获取或分发。
本项目不对使用者涉及的数据收集、存储、传输等处理活动的合规性承担责任。使用者应自行遵守相关法律法规,确保处理行为合法正当;因违规操作导致的法律责任由使用者自行承担。
使用者在任何情况下均不得将本项目的作者、贡献者或其他相关方与使用者的使用行为联系起来,或要求其对使用者使用本项目所产生的任何损失或损害负责。
本项目的作者不会提供 KS-Downloader 项目的付费版本,也不会提供与 KS-Downloader 项目相关的任何商业服务。
基于本项目进行的任何二次开发、修改或编译的程序与原创作者无关,原创作者不承担与二次开发行为或其结果相关的任何责任,使用者应自行对因二次开发可能带来的各种情况负全部责任。
本项目不授予使用者任何专利许可;若使用本项目导致专利纠纷或侵权,使用者自行承担全部风险和责任。未经作者或权利人书面授权,不得使用本项目进行任何商业宣传、推广或再授权。
作者保留随时终止向任何违反本声明的使用者提供服务的权利,并可能要求其销毁已获取的代码及衍生作品。
作者保留在不另行通知的情况下更新本声明的权利,使用者持续使用即视为接受修订后的条款。
在使用本项目的代码和功能之前,请您认真考虑并接受以上免责声明。如果您对上述声明有任何疑问或不同意,请不要使用本项目的代码和功能。如果您使用了本项目的代码和功能,则视为您已完全理解并接受上述免责声明,并自愿承担使用本项目的一切风险和后果。