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 相关文章推荐
Python3.0与2.X版本的区别实例分析
Aug 25 Python
在Python中关于中文编码问题的处理建议
Apr 08 Python
Python运算符重载用法实例
May 28 Python
Python中使用Counter进行字典创建以及key数量统计的方法
Jul 06 Python
Python3.5内置模块之os模块、sys模块、shutil模块用法实例分析
Apr 27 Python
python+numpy实现的基本矩阵操作示例
Jul 19 Python
python实现横向拼接图片
Mar 23 Python
pycharm下配置pyqt5的教程(anaconda虚拟环境下+tensorflow)
Mar 25 Python
python如何导出微信公众号文章方法详解
Aug 31 Python
如何通过安装HomeBrew来安装Python3
Dec 23 Python
scrapy-splash简单使用详解
Feb 21 Python
详细介绍python操作RabbitMq
Apr 12 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获取谷歌PR值算法,附上php查询PR值代码示例
2011/12/25 PHP
php+jQuery递归调用POST循环请求示例
2016/10/14 PHP
最近项目写了一些js,水平有待提高
2009/01/31 Javascript
jquery nth-child()选择器的简单应用
2010/07/10 Javascript
在JavaScript中获取请求的URL参数
2010/12/22 Javascript
运用jQuery定时器的原理实现banner图片切换
2014/10/22 Javascript
Javascript 5种方法实现过滤删除前后所有空格
2016/06/22 Javascript
无阻塞加载js,防止因js加载不了影响页面显示的问题
2016/12/18 Javascript
Jquery Easyui自定义下拉框组件使用详解(21)
2020/12/31 Javascript
javascript replace()第二个参数为函数时的参数用法
2016/12/26 Javascript
Javascript下拉刷新的简单实现
2017/02/14 Javascript
Angular.Js中过滤器filter与自定义过滤器filter实例详解
2017/05/08 Javascript
nodeJS微信分享
2017/12/20 NodeJs
Angular使用动态加载组件方法实现Dialog的示例
2018/05/11 Javascript
vue.js响应式原理解析与实现
2020/06/22 Javascript
详解Puppeteer前端自动化测试实践
2019/02/21 Javascript
在JavaScript中如何访问暂未存在的嵌套对象
2019/06/18 Javascript
Vue js with语句原理及用法解析
2020/09/03 Javascript
Vue + ts实现轮播插件的示例
2020/11/10 Javascript
详解vue 组件注册
2020/11/20 Vue.js
python实现复制整个目录的方法
2015/05/12 Python
Windows环境下python环境安装使用图文教程
2018/03/13 Python
Python针对给定字符串求解所有子序列是否为回文序列的方法
2018/04/21 Python
python如何保存文本文件
2020/06/07 Python
最简单的matplotlib安装教程(小白)
2020/07/28 Python
Soft Cotton捷克:来自爱琴海棉花的浴袍
2017/02/01 全球购物
迪拜领先运动补剂零售品牌中文站:Sporter商城
2019/08/20 全球购物
公司总经理岗位职责范本
2014/08/15 职场文书
社区活动策划方案
2014/08/21 职场文书
单方投资意向书
2015/05/11 职场文书
推普标语口号大全
2015/12/26 职场文书
小学五年级(说明文3篇)
2019/08/13 职场文书
单身狗福利?Python爬取某婚恋网征婚数据
2021/06/03 Python
python中使用 unittest.TestCase单元测试的用例详解
2021/08/30 Python
浅谈Redis的keys命令到底有多慢
2021/10/05 Redis
Python 数据可视化之Bokeh详解
2021/11/02 Python