你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

我相信如果看电影的都知道,不管是爱奇艺还是腾讯视频还是优酷很多的电影电视都是需要VIP的,但是为了看这么一个电视或者电影开个vip又不是很划算,小编今天教大家如何利用Python来下载VIP的视频,这个方法还是挺实用的,希望能帮到那些喜欢看电视或者想学的Python的小伙伴们学习!案例说难也不难,对零基础的小伙伴来讲就可能相对来说有点难......

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

好了,废话不多说。现在开始我们的实战之旅吧!

实战背景

爱奇艺的VIP视频只有会员能看,普通用户只能看前6分钟。比如加勒比海盗5的URL:http://www.iqiyi.com/v_19rr7qhfg0.html#vfrm=19-9-0-1

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

http://api.xfsub.com/index.php?url=[播放地址或视频id]

比如,对于绣春刀这个电影,我们只需要在浏览器地址栏输入:

http://api.xfsub.com/index.php?url=http://www.iqiyi.com/v_19rr7qhfg0.html#vfrm=19-9-0-1

这样,我们就可以在线观看这些VIP视频了:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

我们可以看到,有用的请求并不多,我们逐条分析。我们先看第一个请求返回的信息。

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

可以看到第一个请求是GET请求,没有什么有用的信息,继续看下一条。

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

我们看到,第二条GET请求地址变了,并且在返回的信息中,我们看到,这个网页执行了一个POST请求。POST请求是啥呢?它跟GET请求正好相反,GET是从服务器获得数据,而POST请求是向服务器发送数据,服务器再根据POST请求的参数,返回相应的内容。这个POST请求有四个参数,分别为time、key、url、type。记住这个有用的信息,我们在抓包结果中,找一下这个请求,看看这个POST请求做了什么。

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

这里面存放的是什么东西?不会视频解析后的地址吧?我们有浏览器打开这个地址看一下:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

果然,我们可以看到视频地址近在眼前啊,URL如下:

我们再打开这个视频地址:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

思路已经给出,希望喜欢爬虫的人可以在运行下代码之后,自己重头编写程序,因为只有经过自己分析和测试之后,才能真正明白这些代码的意义。上述代码运行结果如下:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

我们已经顺利获得了mp4这个视频文件地址。根据视频地址,使用 urllib.request.urlretrieve() 即可将视频下载下来。编写代码如下:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

urlretrieve()有三个参数,第一个url参数是视频存放的地址,第二个参数filename是保存的文件名,最后一个是回调函数,它方便我们查看下载进度。代码量不大,很简单,主要在于分析过程。代码运行结果如下:

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

下载速度挺快的,几分钟视频下载好了。

你还在付费爱奇艺VIP?神级程序员教你用Python任意下!

对于这个程序,感兴趣的朋友可以进行扩展一下,设计出一个小软件,根据用户提供的url,提供PC在线观看、手机在线观看、视频下载等功能。

总结

爬虫时效性低,同样的思路过了一个月,甚至一周可能无法使用,但是爬取思路都是如此,完全可以自行分析。

来自:Python3网络爬虫快速入门实战解析 | Jack Cui

http://cuijiahua.com/blog/2017/10/spider_tutorial_1.html

始发于微信公众号: 程序员之家

本文由 华盟网 作者:congtou 发表,其版权均为 华盟网 所有,文章内容系作者个人观点,不代表 华盟网 对观点赞同或支持。如需转载,请注明文章来源。

2
绾绾

相关文章

发表评论

电子邮件地址不会被公开。