首页 > 编程语言 > 软件测试|手把手教你使用Python获取B站视频选集内容

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

时间:2023-02-08 18:31:39浏览次数:66  
标签:selenium Python 手把手 list chromedriver print browser page 软件测试

背景

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

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

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

当然这些选集的字段我们肉眼也是可以看得到的。只是通过程序来实现的话,可能真没有想象的那么简单。那么这篇文章的目标呢,就是通过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("https://www.bilibili.com/video/BV1CZ4y1a7Rn")

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

常见问题

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

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

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

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

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

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

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

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


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

​更多技术文章​

标签:selenium,Python,手把手,list,chromedriver,print,browser,page,软件测试
From: https://blog.51cto.com/u_15640304/6044723

相关文章

  • ubuntu18容器中安装python3.10
    在python官网https://www.python.org/下载python3.10的tgz的源码包。安装编译环境apt-getupdateaptinstallwgetbuild-essentialcheckinstallaptinstalllibreadline......
  • Kong Customize Python Plugin
    KongCustomizePythonPlugin前情提要:由于公司业务需求,需要针对Kong自定义插件,而Kong的插件主要是Lua语言,公司的技术栈是Python,所以升级了Kong版本到3.1。Kon......
  • 腾讯课堂Python使用Numpy入门数据计算
    p2array创建及属性array元素类型相同,list可不同1.array转化一维数组importnumpyasnplis=[1]np.array(lis)2.array转化二维数组importnumpy......
  • python 弹窗、提示和警告框MessageBox部件
    需要安装pywin32模块pipinstallpywin32-ihttp://pypi.douban.com/simple/--trusted-hostpypi.douban.comimportwin32api,win32con##提醒OK消息框win32api.MessageBo......
  • 2023 年 2 月国内 ChatGpt 正确注册教程,手把手教你使用(亲测可用)
    刚过完年,不知道大家有没有在春节档期间,跟家人一起观看《流浪地球2》,里面的MOSS,是一款强大的智能机器人。那么当时我们就可以联想到的最近发布的ChatGPT,同样作为一款现实中......
  • Python-函数
    内建函数help()help(list.append)  #显示list的append方法的帮助 input()name=input('pleaseenteryourname:')#读取输入,将读取到的数据赋值给指定变量 rang......
  • PYTHONPATH与import(模块导入)
    1.Python环境变量下面几个重要的环境变量,它应用于Python:变量名描述PYTHONPATHPYTHONPATH是Python搜索路径,默认我们import的模块都会从PYTHONPATH里面寻找。PYT......
  • python获取数据库字段的2种处理思路:文件处理和SQL处理
    问题:接到这样一个需求,定时查数据库表table_a,table_b,table_c中的数据,当有新增的时候,把table中的新增的数据中,所有message字段发出来解决思路一:1.思索后,因为3个table结构一......
  • Python-类
    classCocaCola:formula=['caffeine','sugar','water','soda']#类的属性coke_for_me=CocaCola()#类的实例化coke_for_you=CocaCola()#类的实例化print(CocaCo......
  • 【Python】 使用__init__.py 自动安装import失败的三方库
    __init__.py文件方法一:遍历列表#coding:utf-8importos,sys#三方库如果引用的库未安装,则自动安装try:#importMatplotlib#绘制折线图、函数图、柱状......