專 欄

如何快速爬取B站全站视频信息


陈键冬,Python中文社区专栏作者,知乎专栏:尽瞎扯
GitHub:
https://github.com/chenjiandongx


B站我想大家都熟悉吧,其实 B 站的爬虫网上一搜一大堆。不过纸上得来终觉浅,绝知此事要躬行,我码故我在。最终爬取到数据总量为 760万 条。

准备工作

首先打开 B 站,随便在首页找一个视频点击进去。常规操作,打开开发者工具。这次是目标是通过爬取 B 站提供的 api 来获取视频信息,不去解析网页,解析网页的速度太慢了而且容易被封 ip。

勾选 JS 选项,F5 刷新

如何快速爬取B站全站视频信息

找到了 api 的地址

如何快速爬取B站全站视频信息

复制下来,去除没必要的内容,得到https://api.bilibili.com/x/web-interface/archive/stat?aid=15906633 ,用浏览器打开,会得到如下的 json 数据

如何快速爬取B站全站视频信息

动手写码

好了,到这里代码就可以码起来了,通过 request 不断的迭代获取数据,为了让爬虫更高效,可以利用多线程。

核心代码

如何快速爬取B站全站视频信息

迭代爬取

如何快速爬取B站全站视频信息

整个项目的最主要部分的代码也就是 20 行左右,挺简洁的。

运行的效果大概是这样的,数字是已经已经爬取了多少条链接,其实完全可以在一天或者两天内就把全站信息爬完的。

如何快速爬取B站全站视频信息

至于爬取后要怎么处理就看自己爱好了,我是先保存为 csv 文件,然后再汇总插入到数据库。

数据库表

如何快速爬取B站全站视频信息

由于这些内容是我在几个月前爬取的,所以数据其实有些滞后了。

数据总量

如何快速爬取B站全站视频信息

查询播放量前十的视频

如何快速爬取B站全站视频信息

查询回复量前十的视频

如何快速爬取B站全站视频信息

各种花样查询任君选择!!视频的链接为https://www.bilibili.com/video/av + v_aid 
详细代码请移步至 bili.py,项目地址:chenjiandongx/bili-spider 欢迎围观


如何快速爬取B站全站视频信息

长按扫描关注Python中文社区,

获取更多技术干货!

    

Python 中 文 社 区

Python中文开发者的精神家园

合作、投稿请联系微信:

pythonpost

— 人生苦短,我用Python —
1MEwnaxmMz7BPTYzBdj751DPyHWikNoeFS



本文为作者原创作品,未经作者授权同意禁止转载

如何快速爬取B站全站视频信息


相关文章:

  • 2021-07-11
  • 2022-01-23
  • 2021-12-18
  • 2022-12-23
  • 2021-09-30
  • 2022-01-30
  • 2021-10-20
  • 2021-11-06
猜你喜欢
  • 2021-10-21
  • 2021-11-20
  • 2022-12-23
  • 2021-08-25
  • 2022-01-28
  • 2022-12-23
  • 2021-08-22
相关资源
相似解决方案