抖音爬虫 | 手把手教你下载指定的Douyin)号的视频
作者 | loadchange
整理 | Xiaowen
原文 | 专知
链接:
https://github.com/LoadChange/amemv-crawler
这是一个Python的脚本,配置运行后可以下载指定抖音用户的全部视频(含收藏),也可以下载指定主题(挑战)或音乐下的全部视频。这个项目是一个练手项目,源码仅作为和大家一起学习Python使用,你可以免费: 拷贝、分发和派生当前源码。你不可以用于商业目的及其他恶意用途。
另外本项目要完成的功能是将视频成功下载,有一些朋友在 issue 中提出了一些超预期的需求,比如视频改名、下载图片、视频宽高、发布数据和播放点赞等等, 这些完善可能是对项目十分有利的,但是我没有时间去一一处理,所以对于这样的需求请不要在发issue上来了,可以直接提 Pull requests 上来。
还有一些是对 as、 cp 、mas 的探讨,对于这些也不在我们的项目范围内,最后是服务端对抓取的一些限制,如抓取频率、IP等等,如果你遇到了这样的问题, 可能你的下载量已经超出了学习目的,对此我也拒绝支持并表示非常抱歉。
对于上述所不支持的问题以外,欢迎大家多提issue,同时也仅支持在 issues 中反馈问题, 使用 email 和我联系的同学,以后我就不在回复啦,私人邮箱很少登录,回复也不及时,哈哈。? 最后希望和大家共同学习和进步。
环境安装
程序猿和程序媛见这里
配置好你的Python、node环境,然后pip install requests
.
或者
$ git clone https://github.com/loadchange/amemv-crawler.git$ cd amemv-crawler$ pip install -r requirements.txt
大功告成,直接跳到下一节配置和运行.
配置和运行
有两种方式来指定你要下载的抖音号分享链接,一是编辑share-url.txt
,二是指定命令行参数.
第一种方法:编辑share-url.txt文件
找到一个文字编辑器,然后打开文件share-url.txt
,把你想要下载的抖音号分享链接编辑进去,以逗号/空格/tab/表格鍵/回车符分隔,可以多行.例如, 这个文件看起来是这样的:
https://www.douyin.com/share/user/85860189461?share_type=link&tt_from=weixin&utm_source=weixin&utm_medium=aweme_ios&utm_campaign=client_share&uid=97193379950&did=30337873848,https://www.iesdouyin.com/share/challenge/1593608573838339?utm_campaign=clien,https://www.iesdouyin.com/share/music/6536362398318922509?utm_campaign=client_share&app=aweme&utm_medium=ios&iid=30337873848&utm_source=copy
获取用户分享链接的方法(挑战、音乐 类似)
然后保存文件,双击运行amemv-video-ripper.py
或者在终端(terminal)里面 运行python amemv-video-ripper.py
第二种方法:使用命令行参数(仅针对会使用操作系统终端的用户)
如果你对Windows或者Unix系统的命令行很熟悉,你可以通过指定运行时的命令行参数来指定要下载的站点:
某些平台下注意给URL增加引号
python amemv-video-ripper.py URL1,URL2
分享链接以逗号分隔,不要有空格.
视频的下载与保存
程序运行后,会默认在当前路径下面生成一个跟抖音ID名字相同的文件夹, 视频都会放在这个文件夹下面.
运行这个脚本,不会重复下载已经下载过的视频,所以不用担心重复下载的问题.同时,多次运行可以 帮你找回丢失的或者删除的视频.
然后重新运行下载命令.
高级应用
如果你想下载整个挑战主题,请在 share-url.txt 文件中添加 挑战的分享URL
如果你想下载按音乐去下载,请在 share-url.txt 文件中添加 音乐的分享URL
如下: 既为抖音号、挑战主题和音乐的三种爬虫方式,需要注意的是,爬虫只对搜索结果第一的结果进行下载,所以请尽量完整的写出你的 主题或音乐名称。
https://www.douyin.com/share/user/85860189461?share_type=link&tt_from=weixin&utm_source=weixin&utm_medium=aweme_ios&utm_campaign=client_share&uid=97193379950&did=30337873848,https://www.iesdouyin.com/share/challenge/1593608573838339?utm_campaign=clien,https://www.iesdouyin.com/share/music/6536362398318922509?utm_campaign=client_share&app=aweme&utm_medium=ios&iid=30337873848&utm_source=copy
短地址的情况
http://v.douyin.com/cDo2P/,http://v.douyin.com/cFuAN/,http://v.douyin.com/cMdjU/
处理意外
2018-04-14 用户列表接口新增字段_signature,该字段是由douyin_falcon:node_modules/byted-acrawler/dist/runtime
生成的,所以我们需要先fuck byted-acrawler
一下,拿到signature,才能继续前行。请安装好python的环境之后 顺手安装node 以便顺利的fuck byted-acrawler
2018-06-22 分享出现短地址,解决办法:读取到 v.douyin.com 的任务时,尝试请求,在302的情况下取Response Headers中Location。
2018-07-02 更新了 douyin_falcon:node_modules/byted-acrawler/dist/runtime,我们保持同步更新 fuck-byted-acrawler.js !
2018-07-12 用户视频接口 https://www.douyin.com/aweme/v1/aweme/post/ 增加参数dytk, 这个参数在页面中直接取。
2018-09-03 修正用户视频列表接口域名 douyin.com to amemv.com
2018-09-25 抖音关闭原无水印720P下载地址,临时降级为有水印方案
2018-10-01 恢复无水印下载
2018-11-20 海外版 Tik Tok
切换无水印视频源
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 如何将SAP Document Builder的word控件设置成只读模式
- 在SAP CRM WebClient UI里打开ABAP Webdynpro页面
- SAP CRM WebClient UI和ABAP Webdynpro页面的互相跳转
- 通过 Apache Ant 来运行 Tomcat
- 你要的干货!信息收集之绕过CDN获取真实网站IP方法总结
- ES聚合操作
- leetcode-easy-array-删除排序数组中的重复项
- SQL注入靶场之SQLiLabs搭建指南
- [OHIF-Viewers]医疗数字阅片-医学影像-redux-token实操(1)
- [OHIF-Viewers]医疗数字阅片-医学影像-屏蔽StudyList病例列表
- Ant Design for Vue的Table组件一列显示多个参数
- 【React】React-router的使用记录
- Blazor带我重玩前端(四)
- Android绘制系统简介
- E: Sub-process /usr/bin/dpkg returned an error code (1) 解决方案