Airtest-Selenium实操小课:刷B站视频

这篇具有很好参考价值的文章主要介绍了Airtest-Selenium实操小课:刷B站视频。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试

2024软件测试面试刷题,这个小程序(永久刷题),靠它快速找到工作了!(刷题APP的天花板)_软件测试刷题小程序-CSDN博客文章浏览阅读2.5k次,点赞85次,收藏11次。你知不知道有这么一个软件测试面试的刷题小程序。里面包含了面试常问的软件测试基础题,web自动化测试、app自动化测试、接口测试、性能测试、自动化测试、安全测试及一些常问到的人力资源题目。最主要的是他还收集了像阿里、华为这样的大厂面试真题,还有互动交流板块……_软件测试刷题小程序https://blog.csdn.net/AI_Green/article/details/134931243?spm=1001.2014.3001.55021. 前言

上一课我们讲到用Airtest-Selenium爬取网站上我们需要的信息数据,还没看的同学可以戳这里看看~

那么今天的推文,我们就来说说看,怎么实现看b站、刷b站的日常操作,包括点击暂停,发弹幕,点赞,收藏等操作,仅供大家参考学习~

2.需求分析和准备

整体的需求大致可以分为以下步骤:

  • 打开chrome浏览器

  • 打开百度网页

  • 搜索“哔哩哔哩”

  • 点击进入“哔哩哔哩”官网

  • 搜索关键词“Airtest酱”

  • 点击进入“Airtest酱”首页,随机点击播放视频

  • 并对视频点击暂停,发弹幕,点赞,收藏

在写脚本之前,我们需要准备好社区版AirtestIDE(目前最新版为1.2.16),设置好chrome.exe地址和对应的driver;并且确保我们的chrome浏览器版本不是太高以及selenium是4.0以下即可(这些兼容问题我们都会在后续的版本修复)。

3. 脚本实现与运行效果

3.1 脚本运行效果

我们在编写这次代码的时候,我们主要是使用了页面元素定位的方式去进行操作交互的,除此之外还实现了保存cookie、读取cookie的一个操作。大家在日常使用也会发现,在首次通过脚本开启的chrome网页界面是无cookie的,那么我们在进行一些任务之前是需要先登录后才能进行下一步操作的,可以通过首次登录时读取cookie数据保存到本地,往后每次运行只需要读取本地的cookie文件就可以轻松登录啦~

先来看下我们整体的运行效果:

Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试

3.2 完整代码分享

这里也附上完整的示例代码给大家参考,有需要的同学可以自取学习哦:

# -*- encoding=utf8 -*-
from airtest.core.api import *
# 引入selenium的webdriver模块
from airtest_selenium.proxy import WebChrome
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
import threading
import time
import random
import json

#保存以及调用cookie的线程
class UtilFunc():
def cookie_is_exist_(self, cook_name='_'): # 检查txt文件是否存在
if os.path.exists(f'{cook_name}cookies.txt'):
return True
return False

def cookie_save_(self, driver, cook_name='_'): #保存cookie到txt文件中以便下次读取
# 获取当前页面的所有cookie
cookies = driver.get_cookies()
# 将cookie转换为JSON字符串
cookies_json = json.dumps(cookies)
# 保存cookie到txt文件
with open(f'{cook_name}cookies.txt', 'w') as file:
file.write(cookies_json)
print(f"保存cookies:{cookies}")

def cookie_set_(self, driver, cook_name='_'): #读取cookie文件并给当前网站设置已存cookie
# 从txt文件读取JSON_cookie数据
with open(f'{cook_name}cookies.txt', 'r', encoding='gbk') as file:
json_data = file.read()
# 将JSON数据转换为列表
data_list = json.loads(json_data)
for cookie in data_list:
driver.add_cookie(cookie)
print("设置cookie")


# 创建一个实例,代码运行到这里,会打开一个chrome浏览器
driver = WebChrome()
isLogin = False #存储登录状态值,False为未登录,True为已登录

#打开chrome浏览器并打开视频播放
def start_selenium():
driver.implicitly_wait(20)
driver.get("https://www.baidu.com/")
# 输入搜索关键词并提交搜索
search_box = driver.find_element_by_name('wd')
search_box.send_keys('哔哩哔哩')
search_box.submit()

try:
# 查找搜索结果中文本为 "哔哩哔哩" 的元素并点击
results = driver.find_elements_by_xpath('//div[@id="content_left"]//span[contains(text(), "哔哩哔哩")]')
if results:
results[0].click()
print("点击了哔哩哔哩搜索结果")
except Exception as e:
element = driver.find_element_by_xpath(
"//div[@id='content_left']/div[@id='1']/div[@class='c-container']/div[1]/h3[@class='c-title t t tts-title']/a")
element.click()
driver.switch_to_new_tab() # 切换界面

util_cookie = UtilFunc()
if util_cookie.cookie_is_exist_("Airtest酱登录"): # 存在cookie文件,设置cookie
util_cookie.cookie_set_(driver, "Airtest酱登录")
# 输入搜索关键词并提交搜索
search_box = driver.find_element_by_class_name('nav-search-input')
search_box.send_keys('Airtest酱')
# 模拟发送Enter键
search_box.send_keys(Keys.ENTER)
sleep(5)
driver.switch_to_new_tab() # 切换界面

results_ = driver.find_elements_by_xpath(
'//div[@class="bili-video-card__info--right"]//span[contains(text(),"Airtest酱")]')
if results_:
results_[0].click()
driver.switch_to_new_tab() # 切换界面

driver.refresh()
sleep(2)
video_ele = driver.find_element_by_xpath("//div[@title='14天Airtest自动化测试小白课程']")
# 滚动到指定元素处
driver.execute_script("arguments[0].scrollIntoView(true);", video_ele)
sleep(5)
video_ele.click()
driver.switch_to_new_tab() # 切换界面

# 获取所有视频
video_list = driver.find_elements_by_xpath("//ul[@class='row video-list clearfix']//a[@class='title']")
random_element = random.choice(video_list)
random_element.click() # 随机播放一个
driver.switch_to_new_tab() # 切换界面

#登录
def is_login():
"""线程检测登录弹窗"""

def is_no_login(*args):
global isLogin # 在线程内修改外部常量的值
no_login_tip = True
while True:
element = driver.find_elements_by_css_selector('.bili-mini-content-wp')
if len(element) > 0:
if no_login_tip:
print("未登录 请在五分钟内扫码")
no_login_tip = False
else:
print("未检测到登录弹窗")
check_login_ele = driver.find_elements_by_css_selector('.bpx-player-dm-wrap')
if not check_login_ele:
isLogin = True
UtilFunc().cookie_save_(driver, "Airtest酱登录")
print("保存cookie")
break
log_text_array = [element.text for element in check_login_ele] # 使用列表推导式简化代码
if "请先登录或注册" in log_text_array:
loginbtn = driver.find_elements_by_xpath(
"//div[@class='bili-header fixed-header']//div[@class='header-login-entry']")
if loginbtn:
loginbtn[0].click()
isLogin = False
print("判断cookie文件是否存在,方便下次调用,设置后刷新页面")
else:
isLogin = True
UtilFunc().cookie_save_(driver, "Airtest酱登录")
print("保存cookie")
break

thread = threading.Thread(target=is_no_login, args=("args",))
thread.start()

#暂停播放
def video_pause_and_play(check_btn=False):
if isLogin:
try:
paus_btn = driver.find_elements_by_xpath(
"//*[@id=\"bilibili-player\"]//div[@class='bpx-player-ctrl-btn bpx-player-ctrl-play']")
if paus_btn[0]:
detection_time1 = driver.find_elements_by_xpath(
'//*[@class="bpx-player-control-bottom-left"]//div[@class="bpx-player-ctrl-time-label"]')
start_time = detection_time1[0].text
sleep(5)
# 时间戳检测是否在播放
detection_time2 = driver.find_elements_by_xpath(
'//*[@class="bpx-player-control-bottom-left"]//div[@class="bpx-player-ctrl-time-label"]')
end_time = detection_time2[0].text
if start_time == end_time or check_btn:
print("点击播放(暂停)按钮")
paus_btn[0].click()
except Exception as e:
print(f"点击播放(暂停)出错{e}")

#发送弹幕
def video_sms(sms_body="不错"):
if isLogin:
try:
sms_input_edit = driver.find_element_by_xpath("//input[@class='bpx-player-dm-input']")
sms_input_edit.send_keys(sms_body)
# 模拟发送Enter键
sms_input_edit.send_keys(Keys.ENTER)
except Exception as e:
print(f"发弹幕出错{e}")
print(f"发送弹幕:{sms_body}")

#点赞
def video_love():
if isLogin:
print("点赞")
try:
sms_input_edit = driver.find_elements_by_xpath(
"//div[@class='toolbar-left-item-wrap']//div[@class='video-like video-toolbar-left-item']")
if not sms_input_edit:
print("已经点赞")
return
sms_input_edit[0].click()
except Exception as e:
print(f"点赞出错{e}")

#收藏
def video_collect():
if isLogin:
print("收藏")
try:
colle_btn = driver.find_elements_by_xpath(
"//div[@class='toolbar-left-item-wrap']//div[@class='video-fav video-toolbar-left-item']")
if not colle_btn:
print("已经收藏")
return
colle_btn[0].click()
sleep(2)
list_coll = driver.find_elements_by_xpath("//div[@class='group-list']//ul/li/label")
random_element = random.choice(list_coll) # 随机收藏
# 滚动到指定元素处
driver.execute_script("arguments[0].scrollIntoView(true);", random_element)
sleep(2)
random_element.click() # 随机收藏一个
sleep(2)
driver.find_element_by_xpath("//div/button[@class='btn submit-move']").click() # 确认收藏
except Exception as e:
print(f"收藏出错{e}")


# 等待元素出现
def wait_for_element(driver, selector, timeout=60 * 5):
try:
element = WebDriverWait(driver, timeout).until(
EC.presence_of_element_located((By.XPATH, selector))
)
return element
except Exception:
print("元素未出现")
return None

#头像元素初始化
selem = "//div[@class='bili-header fixed-header']//*[contains(@class, 'header-avatar-wrap--container mini-avatar--init')]"

if __name__ == "__main__":
start_selenium() # 开启浏览器找到视频播放
is_login() # 检测是否出现登录弹窗
# 等待元素出现
element = wait_for_element(driver, selem)
if element:
print("检测到已经登录")
# 暂停和播放视频
for _ in range(2):
video_pause_and_play()
sleep(3)
driver.refresh()
# 发送弹幕
sms_list = ["感觉不错,收藏了", "666,这么强", "自动化还得看airtest", "干货呀", "麦克阿瑟直呼内行"]
for item in sms_list:
wait_time = random.randint(5, 10) # 随机生成等待时间,单位为秒
time.sleep(wait_time) # 等待随机的时间
video_sms(item) # 评论

# 点赞和收藏视频
for action in [video_love, video_collect]:
action()
sleep(3)
else:
print("登录超时")
3.3 重要知识点
1)切换新页面并打开新的标签页
driver.switch_to_new_tab()
2)将随机的元素 random_element对象的“顶端”移动到与当前窗口的“顶部”对齐。
driver.execute_script("arguments[0].scrollIntoView(true);", random_element)

3) 从非空序列中随机选取一个数据并返回,该序列可以是list、tuple、str、set

random.choice()

4) 通过实例化threading.Thread类创建线程

target:在线程中调用的对象,可以为函数或者方法;args为target对象的参数。

start():开启线程,如果线程是通过继承threading.Thread子类的方法定义的,则调用该类中的run()方法;start()只能调用一次,否则报RuntimeError。

threading.Thread(target=is_no_login, args=("args",))
thread.start()

5) 使用expected_conditions模块(在使用时通常重命名为EC模块)去判断特定元素是否存在于页面DOM树中,如果是,则返回该元素(单个元素),否则就报错。

EC.presence_of_element_located((By.XPATH, selector))

4. 注意事项与小结

4.1 相关教程
  • 如何使用Airtest-selenium进行web端的页面元素交互

  • 如何设置chromedriver以及一些常见的web脚本问题

  • 为什么AirtestIDE无法检索web控件?

4.2 课程小结

在本周的课程中,我们介绍了如何使用Airtest-selenium进行自动化刷B站视频的操作流程,也分享了Airtest-selenium比较常见的用法。但是,请大家注意,我们的分享仅供学习参考哦!我们分享的代码并不是永远适用的,因为网页的页面元素可能会不断更新。

行动吧,在路上总比一直观望的要好,未来的你肯定会感谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群: 786229024,里面有各种测试开发资料和技术可以一起交流哦。

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取【保证100%免费】Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试
软件测试面试文档
我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试
Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试

Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试

Airtest-Selenium实操小课:刷B站视频,职场日常,自动化测试,软件测试,selenium,测试工具,软件测试,自动化测试,程序员,python,功能测试文章来源地址https://www.toymoban.com/news/detail-837211.html

到了这里,关于Airtest-Selenium实操小课:刷B站视频的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Airtest-Selenium实操小课③:下载可爱猫猫图片

    此文章来源于项目官方公众号:“AirtestProject” 版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途 上次实操小课分享,我们分享了如何使用Airtest-selenium实现自动化刷B站,还没看的同学可以戳这里回顾一下~ 那么这周我们看看如何实现使用Airtest-Selen

    2024年01月25日
    浏览(37)
  • Airtest-Selenium升级兼容Selenium 4.0,给你全新体验!

    此文章来源于项目官方公众号:“AirtestProject” 版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途 在上期更新推文中提到,我们Airtest-Selenium更新到了1.0.6版本,新增支持Selenium4.0的语法,那么我们来看一下Airtest-Selenium更新后有什么新的内容吧~ seleni

    2024年03月14日
    浏览(40)
  • 零基础学会用Airtest-Selenium对Firefox进行自动化测试

    本文将详细介绍如何使用AirtestIDE驱动Firefox测试,以及脱离AirtestIDE怎么驱动Firefox(VScode为例)。 看完本文零基础小白也能学会Firefox浏览器自动化测试!!! 对于Web自动化测试,目前AirtestIDE支持chrome浏览器和Firefox2种浏览器,关于如何驱动chrome浏览器,之前我们的推文已经做

    2024年02月08日
    浏览(117)
  • Airtest全新升级兼容Selenium 4.0,快来看看更新的内容吧

    在上周更新推文中提到,我们Airtest-Selenium更新到了1.0.6版本,新增支持Selenium4.0的语法,那么我们来看一下Airtest-Selenium更新后有什么新的内容吧~ selenium4.0最主要的还是定位元素方法的更新,与旧版本的selenium代码写法存在一些差异,变得更简洁明了。 1. 定位单个元素方法的更

    2024年03月26日
    浏览(41)
  • 【自动化测试入门】用Airtest - Selenium对Firefox进行自动化测试(0基础也能学会)

    本文将详细介绍如何使用AirtestIDE驱动Firefox测试,以及脱离AirtestIDE怎么驱动Firefox(VScode为例)。看完本文零基础小白也能学会Firefox浏览器自动化测试!!! 对于Web自动化测试,目前AirtestIDE支持chrome浏览器和Firefox2种浏览器,今天我们重点聊一下,如何使用AirtestIDE驱动Firef

    2024年02月07日
    浏览(44)
  • AI职场汇报智能办公文案写作效率提升视频教程

    点我访问完整版视频教程 ChatGPT文本创作,一键生成办公文案 AI智能写作,轻松搞定多场景文案写作 智能美化PPT,用AI为职场汇报加速 AI神器联动,十倍提升视频创作效率 点我快速提问提高学习效率 职场办公人群,想要利用人工智能提升办公效率 自媒体副业人士,想要利用人

    2024年02月10日
    浏览(47)
  • 【实操】python opencv将图片合成视频,并插入音频

    简介:将一组图片合成视频,并插入音频。用到opencv,ffmpy,pydub等库。 目录 一、统一图片大小及类型,并按数字排序 二、图片合成视频 三、音频的合并与剪裁 四、音视频融合 opencv基本使用 python对不同尺寸图像改成同一尺寸图像_自动化所副盐的博客-CSDN博客 如何将多张图

    2024年01月16日
    浏览(80)
  • MMAction2-视频理解、行为识别(学习笔记-附代码实操)

    行为识别,时序检测,时空检测三种任务的联系 对于视频的理解 视频 = 空间 + 时间:图像为二维空间,视频是三维,视频相对于图像多出来的维度就是时间维度。 视频理解的重点 重点1:如何描述视频中的动作 ? 动作 = 外观 + 运动。外观是静态的,是图像帧。运动是动态的

    2023年04月09日
    浏览(55)
  • mysql小课(4)

    查询数据select 1、查询全部列 2、查询指定列 3、查询还可以是表达式 因为查询出来的数据形成的是临时表 decimal(3,1)只对原表的数据有作用 而对于临时表是不起作用的 所以说在执行了math+10操作之后会出现108.0这样的数字(有效数字为4位) 查询每个同学的总成绩: 注意: 4、查

    2023年04月10日
    浏览(26)
  • 云小课|MRS基础操作之集群健康检查

    本文分享自华为云社区《云小课|MRS基础操作之集群健康检查》,作者:阅识风云。 阅识风云是华为云信息大咖,擅长将复杂信息多元化呈现,其出品的一张图(云图说)、深入浅出的博文(云小课)或短视频(云视厅)总有一款能让您快速上手华为云。更多精彩内容请单击 此处 。

    2024年02月08日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包