Python selenium抓取虎牙短视频代码实例


Posted in Python onMarch 02, 2020

今天闲着没事,用selenium抓取视频保存到本地,只爬取了第一页,只要小于等于5分钟的视频。。。

为什么不用requests,没有为什么,就因为有些网站正则和xpath都提取不出来想要的东西,要么就是接口出来的数据加密,要么就因为真正的视频url规律难找!

selenium几行代码轻轻松松就搞定!

安装selenium库,设置无界面模式

代码如下:

from selenium import webdriver
from selenium.webdriver.chrome.options import Options
import requests
#设置无界面模式
chrome_options = Options()
chrome_options.add_argument('--headless')
chrome_options.add_argument('--disable-gpu')
 
class VideoCrawl(object):
  video_box=[]#收集video真正的url
  def __init__(self,url):
    self.driver=webdriver.Chrome(executable_path=r"C:\Program Files\python\Lib\site-packages\selenium\webdriver\chrome\chromedriver.exe",options=chrome_options)#设置无界面模式
    self.driver.get(url)
 
  #程序运行完毕,析构函数关闭selenium
  def __del__(self):
    print("爬取结束。。。。。",len(VideoCrawl.video_box),VideoCrawl.video_box)
    self.driver.close()
 
  def run(self):
    self.get_detail_info()
  #获取列表页所有详情页的url
  def get_detail_info(self):
    detail_info = self.driver.find_elements_by_xpath('//a[@class="video-wrap statpid"]')
    detail_url=[]
    for i in detail_info:
      detail_url.append(i.get_attribute('href'))#获取视频页url
    video_playtime_list=self.driver.find_elements_by_xpath('//span[@class="video-duration"]')
    video_playtime_list=[i.text for i in video_playtime_list]
    for res in zip(detail_url,video_playtime_list):
      playtime=res[1].split(":")[0]
      # print("playtime--------",playtime)
      if int(res[1].split(":")[0])<=5:#播放时间小于5分钟的要
        # print(res[0],"解析的url",playtime)
        self.parse_video(res[0],res[1])
      else:
        pass
  #解析详情页
  def parse_video(self,url,t):
    self.driver.get(url)
    videoobj = self.driver.find_elements_by_xpath('//video')
    video_url=videoobj[0].get_attribute('src')
    title=self.driver.find_elements_by_xpath('//h1[@class="video-title"]')[0].text
    print('video_url--------',video_url,title,t)
    #保存video到本地
    self.save_video(video_url,title,t)
    #类变量统计video_url
    VideoCrawl.video_box.append(video_url)
  #保存,请求video_url,二进制保存为mp4
  def save_video(self,url,title,t):
    filename="video"+title+"-"+t.replace(":","")+".mp4"
    video=requests.get(url).content
    with open(filename,"wb") as file:
      file.write(video)
    print(f"{filename}写入文件完毕")
 
if __name__ == '__main__':
  crawl=VideoCrawl('https://v.huya.com/cat/7')
  crawl.run()

运行结果如下:

"C:\Program Files\python\python.exe" C:/Users/Administrator.SC-201903160419/Desktop/note/exer/myapp.py
video_url-------- https://huya-w10.huya.com/2005/265917310/1300/d973823b0f437c9d78fc40b9691fdb54.mp4 【轩子小剧场】最意外的自行车 04:23
video【轩子小剧场】最意外的自行车-0423.mp4写入文件完毕
video_url-------- https://huya-w10.huya.com/2006/267302224/1300/f8a363ec243e4adb2857491f695bc118.mp4 轩子巨2兔:轩子教你演戏 05:06
video轩子巨2兔:轩子教你演戏-0506.mp4写入文件完毕
video_url-------- https://huya-w6.huya.com/2005/264805062/1300/582b726b05db31fc12a1e5557011a6bf.mp4 【麦秀彩儿】跳个舞吧 05:58
video【麦秀彩儿】跳个舞吧-0558.mp4写入文件完毕
video_url-------- https://huya-w10.huya.com/2005/264956230/1300/97fa603f7b174ec30c19013f894bd108.mp4 轩子小剧场:你的女仆请签收 01:18
 
Process finished with exit code -1

Python selenium抓取虎牙短视频代码实例

都可以正常播放。。。

切记:自己娱乐下练练手删了即可,千万不要用于商业用途哦!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中统计函数运行耗时的方法
May 05 Python
在DigitalOcean的服务器上部署flaskblog应用
Dec 19 Python
Python利用BeautifulSoup解析Html的方法示例
Jul 30 Python
tf.truncated_normal与tf.random_normal的详细用法
Mar 05 Python
python下解压缩zip文件并删除文件的实例
Apr 24 Python
Python实现Dijkstra算法
Oct 17 Python
uwsgi+nginx部署Django项目操作示例
Dec 04 Python
Python遍历文件夹 处理json文件的方法
Jan 22 Python
Python&amp;&amp;GDAL实现NDVI的计算方式
Jan 09 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
Feb 13 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
Mar 09 Python
Python matplotlib可视化之绘制韦恩图
Feb 24 Python
Python抓包程序mitmproxy安装和使用过程图解
Mar 02 #Python
python mysql 字段与关键字冲突的解决方式
Mar 02 #Python
python3实现往mysql中插入datetime类型的数据
Mar 02 #Python
python3将变量写入SQL语句的实现方式
Mar 02 #Python
Python *args和**kwargs用法实例解析
Mar 02 #Python
Python通过2种方法输出带颜色字体
Mar 02 #Python
Python实现屏幕录制功能的代码
Mar 02 #Python
You might like
php不用正则验证真假身份证
2013/11/06 PHP
PHP FATAL ERROR: CALL TO UNDEFINED FUNCTION BCMUL()解决办法
2014/05/04 PHP
php实现检查文章是否被百度收录
2015/01/27 PHP
微信自定义菜单的处理开发示例
2015/04/16 PHP
PHP Swoole异步读取、写入文件操作示例
2019/10/24 PHP
PHP 图片处理
2020/09/16 PHP
Javascript 面向对象 继承
2010/05/13 Javascript
从零学JS之你需要了解的几本书
2014/05/19 Javascript
在JavaScript中正确引用bind方法的应用
2015/05/11 Javascript
你知道setTimeout是如何运行的吗?
2016/08/16 Javascript
angular+ionic 的app上拉加载更新数据实现方法
2017/01/16 Javascript
JS实现的五级联动菜单效果完整实例
2017/02/23 Javascript
vue之数据交互实例代码
2017/06/20 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
Angular实现较为复杂的表格过滤,删除功能示例
2017/12/23 Javascript
详解如何在vscode里面调试js和node.js的方法步骤
2018/12/24 Javascript
JS对象属性的检测与获取操作实例分析
2020/03/17 Javascript
[47:03]完美世界DOTA2联赛PWL S3 access vs LBZS 第一场 12.20
2020/12/23 DOTA
python计算N天之后日期的方法
2015/03/31 Python
浅析Python中的多重继承
2015/04/28 Python
Python处理命令行参数模块optpars用法实例分析
2018/05/31 Python
在Python中获取两数相除的商和余数方法
2018/11/10 Python
基于Python在MacOS上安装robotframework-ride
2018/12/28 Python
Django JWT Token RestfulAPI用户认证详解
2019/01/23 Python
使用Python和OpenCV检测图像中的物体并将物体裁剪下来
2019/10/30 Python
python绘制分布折线图的示例
2020/09/24 Python
优秀导游先进事迹材料
2014/01/25 职场文书
幼儿园亲子活动总结
2014/04/26 职场文书
银行金融服务方案
2014/06/11 职场文书
忠诚教育心得体会
2014/09/03 职场文书
法人委托书的范本格式
2014/09/11 职场文书
领导干部学习“三严三实”思想汇报
2014/09/15 职场文书
大学生个人简历自我评价
2015/03/11 职场文书
公司捐书倡议书
2015/04/27 职场文书
起诉状范本
2015/05/20 职场文书
Pygame Time时间控制的具体使用详解
2021/11/17 Python