设为首页收藏本站language→→ 语言切换

鸿鹄论坛

 找回密码
 论坛注册

QQ登录

先注册再绑定QQ

查看: 554|回复: 2
收起左侧

使用Python爬取B站全站视频信息

[复制链接]
发表于 2017-12-7 22:02:14 | 显示全部楼层 |阅读模式
B站我想大家都熟悉吧,其实 B 站的爬虫网上一搜一大堆。不过纸上得来终觉浅,绝知此事要躬行,我码故我在。最终爬取到数据总量为 760万 条。
准备工作
首先打开 B 站,随便在首页找一个视频点击进去。常规操作,打开开发者工具。这次是目标是通过爬取 B 站提供的 api 来获取视频信息,不去解析网页,解析网页的速度太慢了而且容易被封 ip。
勾选 JS 选项,F5 刷新

                               
登录/注册后可看大图

找到了 api 的地址

                               
登录/注册后可看大图

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

                               
登录/注册后可看大图

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

                               
登录/注册后可看大图

迭代爬取

                               
登录/注册后可看大图

整个项目的最主要部分的代码也就是 20 行左右,挺简洁的。
运行的效果大概是这样的,数字是已经已经爬取了多少条链接,其实完全可以在一天或者两天内就把全站信息爬完的。

                               
登录/注册后可看大图

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

                               
登录/注册后可看大图

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

                               
登录/注册后可看大图

查询播放量前十的视频

                               
登录/注册后可看大图

查询回复量前十的视频

                               
登录/注册后可看大图


免费提供最新Linux技术教程书籍,为开源技术爱好者努力做得更多更好,开源站点:http://www.linuxprobe.com/

发表于 2017-12-8 08:18:31 | 显示全部楼层
thanks for sharing
沙发 2017-12-8 08:18:31 回复 收起回复
回复 支持 反对

使用道具 举报

发表于 2017-12-8 12:21:30 | 显示全部楼层
感谢楼主分享!
板凳 2017-12-8 12:21:30 回复 收起回复
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2024-4-19 16:13 , Processed in 0.065830 second(s), 8 queries , Redis On.  

  Powered by Discuz!

  © 2001-2024 HH010.COM

快速回复 返回顶部 返回列表