/TikTokSpider

抖音爬虫,输入指定用户的抖音id,即可下载TA的所有视频作品

Primary LanguagePython

logo

TikTokSpider

dd

使用方法

  1. 运行dyspider.py文件,输入要爬用户的id (注意不是手机端的抖音号)

    dd

  2. 使用命令行参数 --uid 输入用户id

    python dyspider.py --uid 64742778880

欢迎提issue,提优化意见,用过后感觉实用的欢迎star哦

FB1 WARNING! (233)

请仔细阅读说明,确认输入的是用户的抖音ID,而不是用户的抖音号,或者单个视频的ID

  • 抖音号不是抖音ID,抖音ID在这里:

    dd

​ 抖音ID可以通过将主页分享链接发送到电脑,使用浏览器打开查看,分享详细步骤参见

抖音短视频的抖音号-抖音ID怎么看?

https://jingyan.baidu.com/article/90bc8fc8afe4aff652640c7d.html

dd

下载效果

运行代码将会在项目文件夹下新建一个与目标用户同名的文件夹,所有视频皆存入于此

dd

dd

爬虫思路和分析过程

从用户主页的分享页面入手

  1. 进入用户主页,点击 - 分享名片 - 链接形式,将主页分享链接发送到电脑上用chrome打开,就可以看到用户的主页面了

    dd

  2. 但此时还看不到用户的作品,将chrome设置成手机模式,刷新,bingo! 作品出来了

    dd

  3. 点击作品,下拉,查看network,就可以看到我们要找的作品url列表啦

    https://www.amemv.com/aweme/v1/aweme/post/?user_id=6xx1xx0&count=21&max_cursor=0&aid=1128&_signature=TG2uvBAbGAHzG19a.rniF0xtrq&dytk=14d65256b82dd042058b0eca9f85461b
    
  4. 观察一下,这是一个ajax链接,我们需要的所有信息都在返回的包里了

  5. 模拟请求,直接点击链接,copy as curl,然后复制到Postman里转成requests代码

  6. 返回json里有一个has_more字段,如果为1表示还可以下拉出现更多作品,如果为0表示已经是最后

  7. 当我们下拉的时候可以发现,新出现的url里只有max_cursor变了,新出现的max_cursor就是上次请求返回的max_cursor,有了has_more和max_cursor两个参数,我们就可以把所有urls取到了

  8. 写一个递归函数 get_all_video_urls 根据has_more字段将所有urls递归爬取下来,终止条件是has_more==0

  9. 用一个全局变量url_list = [] 存放爬到的每一个视频的名字和地址

  10. 运行编写好的代码后发现,视频数据格式不对,返回去检查,原来第9步中的url不是真实的视频url,而是一个302跳转地址,真实视频地址在第9步response headers里的Location里

  11. 添加禁止跳转的代码,获取真实视频url

    response = requests.request("GET", url, headers=headers, allow_redirects=False)
    video_url = response.headers['Location']

搞定收工!

TodoList:

  • 异常处理
  • 参数检查
  • 显示下载进度条
  • 日志功能