IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 手把手教你使用Python网络爬虫获取B站视频选集内容(附源码) -> 正文阅读

[Python知识库]手把手教你使用Python网络爬虫获取B站视频选集内容(附源码)

一提到B站,第一印象就是视频,相信很多小伙伴和我一样,都想着去利用网络爬虫技术获取B站的视频吧,但是B站视频其实没有那么好拿到的,关于B站的视频获取,之前有介绍通过you-get库进行实现,感兴趣的小伙伴可以看这篇文章:You-Get 就是这么强势!。

言归正传,经常在B站上学习的小伙伴们可能经常会遇到有的博主连载几十个,甚至几百个视频,尤其像这种编程语言、课程、工具使用等连续的教程,就会出现选集系列,如下图所示。

图片

????

当然这些选集的字段我们肉眼也是可以看得到的。只是通过程序来实现的话,可能真没有想象的那么简单。那么这篇文章的目标呢,就是通过Python网络爬虫技术,基于selenium库,实现视频选集的获取。

具体实现

这篇文章我们用的库是selenium,这个是一个用于模拟用户登录的库,虽然给人的感觉是慢,但是在网络爬虫领域,这个库还是用的蛮多的,用它来模拟登录、获取数据屡试不爽。下面是实现视频选集采集的所有代码,欢迎大家亲自动手实践。

# coding: utf-8from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support import expected_conditions as ECfrom selenium.webdriver.support.wait import WebDriverWait
class Item:    page_num = ""        part = ""        duration = ""
   def __init__(self, page_num, part, duration):???????self.page_num?=?page_num???????????????self.part?=?part???????????????self.duration?=?duration
   def get_second(self):            str_list = self.duration.split(":")               sum = 0               for i, item in enumerate(str_list):                    sum += pow(60, len(str_list) - i - 1) * int(item)
       return sum

def get_bilili_page_items(url):    options = webdriver.ChromeOptions()        options.add_argument('--headless')  # 设置无界面        options.add_experimental_option('excludeSwitches', ['enable-automation'])        # options.add_experimental_option("prefs", {"profile.managed_default_content_settings.images": 2,        #                                           "profile.managed_default_content_settings.flash": 0})
   browser = webdriver.Chrome(options=options)       # browser = webdriver.PhantomJS()       print("正在打开网页...")       browser.get(url)
   print("等待网页响应...")       # 需要等一下,直到页面加载完成       wait = WebDriverWait(browser, 10)       wait.until(EC.visibility_of_element_located((By.XPATH, '//*[@class="list-box"]/li/a')))
   print("正在获取网页数据...")       list = browser.find_elements_by_xpath('//*[@class="list-box"]/li')       # print(list)       itemList = []
   second_sum = 0
   # 2.循环遍历出每一条搜索结果的标题       for t in list:           # print("t text:",t.text)               element = t.find_element_by_tag_name('a')               # print("a text:",element.text)               arr = element.text.split('\n')               print(" ".join(arr))               item = Item(arr[0], arr[1], arr[2])               second_sum += item.get_second()               itemList.append(item)
   print("总数量:", len(itemList))       # browser.page_source
   print("总时长/分钟:", round(second_sum / 60, 2))       print("总时长/小时:", round(second_sum / 3600.0, 2))
   browser.close()
   return itemList
get_bilili_page_items("https://www.bilibili.com/video/BV1Eb411u7Fw")

这里用到的选择器是xpath,利用视频示例是B站的《高等数学》同济版 全程教学视频(宋浩老师)视频选集,大家如果想抓取其他视频选集的话,只需要更改上述代码的最后一行的URL链接即可。

常见问题????

在运行过程中小伙伴们应该会经常遇到这个问题,如下图所示。

图片

????

这个是因为谷歌驱动版本问题导致的,只需要根据提示,去下载对应的驱动版本即可,驱动下载链接:

https://chromedriver.storage.googleapis.com/index.html

图片

总结

我是Python进阶者。这篇文章主要给大家介绍了B站视频选集内容的获取方法,基于网络爬虫,通过selenium库和xpath选择器进行实现,并且给大家例举了常见问题的处理方法。小伙伴们,快快用实践一下吧更多精彩在公众号:编程简单学丶(点击相关资料)python相关资料

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-10-15 11:45:10  更:2021-10-15 11:46:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 23:38:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计