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 base64 decode incorrect padding错误解决方法
Jan 08 Python
Python运用于数据分析的简单教程
Mar 27 Python
Python简单连接MongoDB数据库的方法
Mar 15 Python
python使用paramiko实现远程拷贝文件的方法
Apr 18 Python
Python实现多线程/多进程的TCP服务器
Sep 03 Python
pygame实现五子棋游戏
Oct 29 Python
Django 简单实现分页与搜索功能的示例代码
Nov 07 Python
Python2与Python3的区别点整理
Dec 12 Python
Python调用钉钉自定义机器人的实现
Jan 03 Python
keras 获取某层的输入/输出 tensor 尺寸操作
Jun 10 Python
keras:model.compile损失函数的用法
Jul 01 Python
python 实现图片修复(可用于去水印)
Nov 19 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
ThinkPHP实现ajax仿官网搜索功能实例
2014/12/02 PHP
php操作redis缓存方法分享
2015/06/03 PHP
利用PHP如何实现Socket服务器
2015/09/23 PHP
xml 与javascript结合的问题解决方法
2007/03/24 Javascript
javascript indexOf函数使用说明
2008/07/03 Javascript
原来Jquery.load的方法可以一直load下去
2011/03/28 Javascript
通过JavaScript使Div居中并随网页大小改变而改变
2013/06/24 Javascript
javascript中对Attr(dom中属性)的操作示例讲解
2013/12/02 Javascript
常用的JS验证和函数汇总
2014/12/23 Javascript
详谈jQuery unbind 删除绑定事件 / 移除标签方法
2017/03/02 Javascript
浅谈angularJS的$watch失效问题的解决方案
2017/08/11 Javascript
分享5个小技巧让你写出更好的 JavaScript 条件语句
2018/10/20 Javascript
Node.js 使用axios读写influxDB的方法示例
2018/10/26 Javascript
JS实现的排列组合算法示例
2019/07/16 Javascript
layui实现给某一列加点击事件
2019/10/26 Javascript
Vue实现兄弟组件间的联动效果
2020/01/21 Javascript
linux 下实现python多版本安装实践
2014/11/18 Python
举例讲解Python的lambda语句声明匿名函数的用法
2016/07/01 Python
Python 快速实现CLI 应用程序的脚手架
2017/12/05 Python
python定向爬虫校园论坛帖子信息
2018/07/23 Python
Python多进程方式抓取基金网站内容的方法分析
2019/06/03 Python
python对常见数据类型的遍历解析
2019/08/27 Python
Python异常模块traceback用法实例分析
2019/10/22 Python
Tensorflow限制CPU个数实例
2020/02/06 Python
Windows系统下pycharm中的pip换源
2020/02/23 Python
PyCharm MySQL可视化Database配置过程图解
2020/06/09 Python
如何完美的建立一个python项目
2020/10/09 Python
FLOS美国官网:意大利高级照明工艺的传奇
2018/08/07 全球购物
什么是Linux虚拟文件系统VFS
2015/08/25 面试题
公司成本主管岗位责任制
2014/02/21 职场文书
2014年共青团工作总结
2014/12/10 职场文书
施工单位工程部经理岗位职责
2015/04/09 职场文书
2015年行政部工作总结
2015/04/28 职场文书
就业推荐表院系意见
2015/06/05 职场文书
2016年党员学习廉政准则心得体会
2016/01/20 职场文书
vue的项目如何打包上线
2022/04/13 Vue.js