×

选集 手把手 软件测试 获取 使用

软件测试|手把手教你使用Python获取B站视频选集内容

jnlyseo998998 jnlyseo998998 发表于2023-03-18 01:12:02 浏览25 评论0

抢沙发发表评论

背景

B站是我们年轻人最喜欢的学习网站,这句话没有任何问题!只有我们想不到的,没有B站上没有的,我们可以在B站上学做饭,学音乐,学数学,学历史…总之,B站就是如此包罗万象。

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

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

具体实现

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

# coding: utf-8

from selenium import webdriver

from selenium.webdriver.common.by import By

from selenium.webdriver.support import expected_conditions as EC

from 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("")

这里用到的选择器是xpath,利用视频示例是我关注的一家软件测试机构的免费课程,大家如果想抓取其他视频选集的话,只需要更改上述代码的最后一行的URL链接即可。

常见问题

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

类似这样的报错信息:This version of ChromeDriver only supports Chrome version,提示chromedriver版本较低,不匹配当前版本的浏览器,需要下载对应版本的chromedriver。

上面这个网址可能访问不了,我们可以访问淘宝镜像下载对应版本的chromedriver

注:chromedriver版本不需要与浏览器完全一致,假如Chrome版本为109.0.5414.120,如下图所示

对应chromedriver列表中没有109.0.5414.120的版本,但是不用担心,只要是109.0.5414.xx版本的驱动都可以正常使用。