当前位置: 代码网 > it编程>网页制作>网页播放器 > WEB自动化测试第一讲—selenium中阶操作

WEB自动化测试第一讲—selenium中阶操作

2024年08月01日 网页播放器 我要评论
selenium可以实现使用键盘输入、alert弹窗、复选框、内联框架等

一、实现键盘输入

selenium可以实现使用键盘输入,需要用到keys方法实现,比如回车,复制,粘贴等等,一下将讲述一下用的最多的

一、回车

具体操作需要导入包,路径为selenium.webdriver.common.keys import keys,但是如何让其使用,也是需要用到send_keys输入,以百度为例,回车键进行搜索。

import time

from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys
# 实例化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开百度网页
driver.get("https://www.baidu.com")
# 设置等待时间
time.sleep(5)
# 输入框输入信息
driver.find_element(by.id,'kw').send_keys("回车")
# 设置等待时间
time.sleep(5)
# 使用回车进行搜索
driver.find_element(by.id, 'kw').send_keys(keys.enter)
# 设置等待时间
time.sleep(5)
# 关闭浏览器
driver.quit()

二、全选

复制使用keys.control,后面加a,进行复制,完全模拟快捷键ctrl+a,界面中会显示代码如下:

import time

from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys

# 实例化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开百度网页
driver.get("https://www.baidu.com")
# 设置等待时间
time.sleep(5)
# 输入框输入信息
driver.find_element(by.id,'kw').send_keys("全选")
# 全选
driver.find_element(by.id, 'kw').send_keys(keys.control,'a')
# 设置等待时间
time.sleep(5)
# 复制
driver.find_element(by.id, 'kw').send_keys(keys.control,'c')
# 设置等待时间
time.sleep(5)
# 关闭浏览器
driver.quit()

 一下是全选到的内容

三、复制

复制使用keys.control,后面加c,进行复制,完全模拟快捷键ctrl+c,将输入框内的文字进行复制下来,代码如下:

import time

import pyperclip
from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys
# 实例化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开百度网页
driver.get("https://www.baidu.com")
# 设置等待时间
time.sleep(2)
# 输入框输入信息
driver.find_element(by.id,'kw').send_keys("复制")
# 全选
driver.find_element(by.id, 'kw').send_keys(keys.control,'a')
# 复制
driver.find_element(by.id, 'kw').send_keys(keys.control,'c')
# 设置等待时间
time.sleep(2)
# 复制
driver.find_element(by.id, 'kw').send_keys(keys.control,'c')
# 设置等待时间
time.sleep(2)
# 使用 pyperclip 获取剪贴板内容
copied_text = pyperclip.paste()
print(copied_text)
# 关闭浏览器
driver.quit()

可以通过剪切板查看是否复制如下图

也可以通过pyperclip模块进行查看 打印出来:

四、粘贴

复制使用keys.control,后面加v,进行粘贴,完全模拟快捷键ctrl+a,将剪切板内的内容粘贴到输入框中。保证你的剪切板内存在数据,代码如下:

import time

from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys
# 实例化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开百度网页
driver.get("https://www.baidu.com")
# 设置等待时间
time.sleep(2)
# 粘贴
driver.find_element(by.id, 'kw').send_keys(keys.control,'v')
# 设置等待时间
time.sleep(2)
# 关闭浏览器
driver.quit()

五、空格

输入框输入空格,使用kys.space 进行输入空格

import time

from selenium import webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.common.keys import keys

# 实例化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开百度网页
driver.get("https://www.baidu.com")
# 设置等待时间
time.sleep(2)
# 输入
driver.find_element(by.id, 'kw').send_keys(keys.space)

time.sleep(5)
# 关闭浏览器
driver.quit()

六、删除

 输入框输入python,使用kys.backspace 进行删除末位n,其中backspace与bacl_space是一样的,都是删除。

二、alert弹窗、下拉框、窗口切换

一、alert弹窗

alert弹窗是系统内自带的,无法通过元素定位来进行操作,但是selenium中提供了alert方法进行使用,alert弹窗分为三种类型:

  1. alert(警告信息)
  2. confirm(确认信息)
  3. prompt(提示输入)

 测试页面代码

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>alert 和 prompt 弹窗示例</title>
</head>
<body>

<button id="alert" onclick="showsimplealert()">显示纯文本弹窗</button>
<button id="confirm" onclick="showconditionalalert()">选择确认或者取消的弹窗</button>
<button  id="prompt" onclick="showinputalert()">显示带有输入框的弹窗</button>

<script>
    // 显示纯文本弹窗
    function showsimplealert() {
        alert("这是一个纯文本的警告框!");
    }

    // 根据输入显示不同弹窗
    function showconditionalalert() {
        confirm("你好,用户")
   }
    // 显示带有输入框的弹窗,并将输入内容显示在另一个弹窗中
    function showinputalert() {
        let userinput = prompt("请输入一些内容:");
        if (userinput) { // 如果用户没有取消且输入了内容
            alert("你输入了:" + userinput);
        } else {
            alert("你取消了输入!");
        }
    }
</script>

</body>
</html>

 代码如下:

import time

from selenium import webdriver
from selenium.webdriver.common.by import by

# 初始化浏览器
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()
# 打开测试文件
driver.get("http://localhost:63342/webauto/day4/alert%e5%bc%b9%e7%aa%97.html")
# 设置等待时间
time.sleep(3)
# 点击按钮,弹出alert弹窗
driver.find_element(by.id, "alert").click()
time.sleep(2)
# 点击确认
driver.switch_to.alert.accept()
time.sleep(3)
# 点击按钮,弹出confirm弹窗
driver.find_element(by.id, "confirm").click()
time.sleep(2)
# 点击取消
driver.switch_to.alert.dismiss()
time.sleep(3)
# 点击按钮,弹出prompt弹窗
driver.find_element(by.id, "prompt").click()
time.sleep(2)
# 输入内容
driver.switch_to.alert.send_keys("hello")
time.sleep(3)
# 点击确认
driver.switch_to.alert.accept()
time.sleep(2)

二、下拉框操作

 下拉框操作有两种方式可以使用,第一种直接模拟手动点击,第二种是使用select方法进行操作,包括了使用索引(select_by_index)进行选择,直接指定值(select_by_value)进行。

测试页面代码

<!doctype html>
<html>
<head>
	<meta charset="utf-8">
	<meta name="viewport" content="width=device-width, initial-scale=1">
	<title></title>
</head>
<body>
	编程语言:<select>
		<option>java</option>
		<option>c++</option>
		<option value="python">python</option>
		<option>html</option>
		<option>javascript</option>
	</select>
</body>
</html>

代码实现如下:

'''
下拉框
'''
import time

import selenium.webdriver as webdriver
from selenium.webdriver.common.by import by
from selenium.webdriver.support import select
# 初始化驱动
driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('http://localhost:63342/webauto/day4/test.html')
time.sleep(2)
# 老办法
driver.find_element(by.xpath,'//select').click()
time.sleep(2)
driver.find_element(by.xpath,'//select/option[2]').click()
# 下拉框
select = select.select(driver.find_element(by.xpath, '//select'))
# 通过索引下拉选择
select.select_by_index(2)
time.sleep(3)
# 通过输入值下拉选择
select.select_by_value('html')
time.sleep(5)

driver.quit()

三、窗口切换

 在进行页面访问时,像点击天猫商城时,页面会自动跳转,这个时候如何进行元素定位点击会报错元素找不到,造成这种的原因是当前的drivern的窗口句柄为第一个页面,并不是自动跳转的页面,这个时候就需要切换句柄使用,先使用

driver.window_handles #获取窗口句柄

之后再去使用索引切换窗口 ,索引:从左往右看是从0开始,为第一个窗口;从右往左看是从-1开始

driver.switch_to.window(win[索引])

测试页面

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>iframe navigation example</title>
    <style>
        .wrap {
            display: flex;
        }
        .aside-wrap {
            flex: 1;
            background-color: #f4f4f4;
        }
        .nab-list {
            list-style: none;
            padding: 0;
        }
        .nav-item {
            margin-bottom: 5px;
        }
        .nav-lk {
            display: block;
            padding: 10px;
            background-color: #ddd;
            color: black;
            text-decoration: none;
        }
        .nav-lk:hover {
            background-color: #ccc;
        }
        .frame-wrap {
            flex: 4;
        }
        iframe {
            width: 100%;
            height: 600px; /* you can adjust the height as needed */
            border: none;
        }
    </style>
</head>
<body>
<div class="wrap">
    <aside class="aside-wrap">
        <ul class="nab-list">
            <li class="nav-item">
                <a href="https://www.taobao.com" target="naviframe" class="nav-lk">淘宝商城</a>
            </li>
            <li class="nav-item">
                <a href="https://www.tmall.com" target="naviframe" class="nav-lk">天猫商城</a>
            </li>
            <li class="nav-item">
                <a href="https://www.suning.com" target="naviframe" class="nav-lk">苏宁商城</a>
            </li>
        </ul>
    </aside>
    <section class="frame-wrap">
        <iframe src="https://www.taobao.com" name="naviframe1"></iframe>
        <iframe src="https://www.tmall.com" name="naviframe2"></iframe>
        <iframe src="https://www.suning.com" name="naviframe3"></iframe>
    </section>
</div>
<script>
    // you might want to add some javascript here if needed
</script>
</body>
</html>

页面跳转之后返回第一个页面,代码实现如下 

import time

import selenium.webdriver as webdriver
from selenium.webdriver.common.by import by

# 初始化驱动

driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('http://localhost:63342/webauto/day4/main.html')
time.sleep(2)

#点击天猫
driver.find_element(by.xpath,'//ul/li[2]').click()
time.sleep(5)

#切换窗口
win = driver.window_handles #获取窗口句柄
# 切回到第一个窗口
driver.switch_to.window(win[0])
time.sleep(10)

如何不切换窗口直接点击天猫内商品,报错报错: nosuchelementexception,代码如下:

import time

import selenium.webdriver as webdriver
from selenium.webdriver.common.by import by

# 初始化驱动

driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('http://localhost:63342/webauto/day4/main.html')
time.sleep(2)
#点击天猫
driver.find_element(by.xpath,'//ul/li[2]').click()
time.sleep(5)
# #切换窗口
# win = driver.window_handles #获取窗口句柄
# # 切回到第一个窗口
# driver.switch_to.window(win[0])
time.sleep(2)
driver.find_element(by.xpath,'//ul[@class="sn-quick-menu"]/li[1]/div/a').click()
time.sleep(10)

报错:

正确代码如下: 

import time

import selenium.webdriver as webdriver
from selenium.webdriver.common.by import by

# 初始化驱动

driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('http://localhost:63342/webauto/day4/main.html')
time.sleep(2)

#点击天猫
driver.find_element(by.xpath,'//ul/li[2]').click()
time.sleep(5)


#切换窗口
win = driver.window_handles #获取窗口句柄
# 切换到当前窗口
driver.switch_to.window(win[1])
time.sleep(2)
driver.find_element(by.xpath,'//ul[@class="sn-quick-menu"]/li[1]/div/a').click()
time.sleep(10)

三、复选框、滑动模块、页面刷新(后退,前进)

一、复选框

 复选框可以直接定位到方框的元素进行点击

 测试页面:

<!doctype html>
<html>
<head>
	<meta charset="utf-8">
	<meta name="viewport" content="width=device-width, initial-scale=1">
	<title></title>
</head>
<body>
	用户名:<input type="text" name="user_name">
	密码:<input type="password" name="pwd">
	<input type="checkbox" name="java">java
	<input type="checkbox" name="python">python
	<input type="checkbox" name="c++">c++
	<input type="checkbox" name="javascript">javascript
	<input type="checkbox" name="html">html
</body>
</html>

代码实现:

import time

import selenium.webdriver as webdriver
from selenium.webdriver.common.by import by

# 初始化驱动

driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('d:\\宏软\\webauto\\day4\\checkbox.html')
time.sleep(2)
# 点击复选框
driver.find_element(by.xpath,'//body/input[4]').click()
time.sleep(5)
driver.quit()

 二、滑动模块

如果遇到滑块问题,如何解决?认为是如何解决的呢,使用鼠标指针进行操作,在selenium中也有指针操作,actionchains模块模拟指针操作。

测试页面

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>滑块解锁封装js方法</title>
    <!--注:这里首次用到了iconfont的语法,即矢量图标-->
    <link rel="stylesheet" href="font/iconfont.css">
    <style>
        *{
            padding: 0;
            margin: 0;
        }
        #box{
            position: relative;
            width: 300px;
            height: 40px;
            margin: 0 auto;
            margin-top: 10px; 
            background-color: #e8e8e8;
            box-shadow: 1px 1px 5px rgba(0,0,0,0.2);
        }
        .bgcolor{
            position: absolute;
            left:0;
            top:0;
            width:40px;
            height: 40px;
            background-color: lightblue;
        }
        .txt{
            position: absolute;
            width: 100%;
            height: 40px;
            line-height: 40px;
            font-size: 14px;
            color: #000;
            text-align: center;
        }
        .slider{
            position: absolute;
            left:0;
            top:0;
            width: 50px;
            height: 38px;
            border: 1px solid #ccc;
            background: #fff;
            text-align: center;
            cursor: move;
        }
        .slider>i{
            position: absolute;
            top:50%;
            left:50%;
            transform: translate(-50%,-50%);
        }
        .slider.active>i{
            color:green;
        }//其实这个图片显示的内容就是"<<"符号。
	.btn {
			position: absolute;
			width: 40px;
			height: 32px;
			background: #fff url() center no-repeat;
			background-size: 13px;//不设置这个属性,背景图片会不成比例的显示
			border: 1px solid #ccc;
			cursor: move;
	}
    </style>
</head>
<body>
    <div id="box" onselectstart="return false;">
        <div class="bgcolor"></div>
        <div class="txt" >滑动解锁</div>
        <!--给i标签添加上相应字体图标的类名即可-->
        <div class="slider"><i class="iconfont icon-double-right"></i></div>
    </div>  
    <script>
        //一、定义了一个获取元素的方法
        function getele(selector){
            return document.queryselector(selector);
        }
        //二、获取到需要用到的dom元素
        var box = getele("#box"),//容器
            bgcolor = getele(".bgcolor"),//背景色
            txt = getele(".txt"),//文本
            slider = getele(".slider"),//滑块
            icon = getele(".slider>i"),
            successmovedistance = box.offsetwidth- slider.offsetwidth,//解锁需要滑动的距离
            downx,//用于存放鼠标按下时的位置
            issuccess = false;//是否解锁成功的标志,默认不成功
 
        //三、给滑块添加鼠标按下事件
        slider.onmousedown = mousedownhandler;
 
        //3.1鼠标按下事件的方法实现
        function mousedownhandler(e){
            bgcolor.style.transition = "";
            slider.style.transition = "";
            var e = e || window.event || e.which;
            downx = e.clientx;
            //在鼠标按下时,分别给鼠标添加移动和松开事件
            document.onmousemove = mousemovehandler;
            document.onmouseup = mouseuphandler;
        };
 
        //四、定义一个获取鼠标当前需要移动多少距离的方法
        function getoffsetx(offset,min,max){
            if(offset < min){
                offset = min;
            }else if(offset > max){
                offset = max;
            }
            return offset;
        }
 
        //3.1.1鼠标移动事件的方法实现
        function mousemovehandler(e){
            var e = e || window.event || e.which;
            var movex = e.clientx;
            var offsetx = getoffsetx(movex - downx,0,successmovedistance);
            bgcolor.style.width = offsetx + "px";
            slider.style.left = offsetx + "px";
 
            if(offsetx == successmovedistance){
                success();
            }
            //如果不设置滑块滑动时会出现问题(目前还不知道为什么)
            e.preventdefault();
        };
 
        //3.1.2鼠标松开事件的方法实现
        function mouseuphandler(e){
            if(!issuccess){
                bgcolor.style.width = 0 + "px";
                slider.style.left = 0 + "px";
                bgcolor.style.transition = "width 0.8s linear";
                slider.style.transition = "left 0.8s linear";
            }
            document.onmousemove = null;
            document.onmouseup = null;
        };
 
        //五、定义一个滑块解锁成功的方法
        function success(){
            issuccess = true;
            txt.innerhtml = "解锁成功";
            bgcolor.style.backgroundcolor ="lightgreen";
            slider.classname = "slider active";
            icon.classname = "iconfont icon-xuanzhong";
            //滑动成功时,移除鼠标按下事件和鼠标移动事件
            slider.onmousedown = null;
            document.onmousemove = null;
        };
    </script>
</body>
</html>

代码实现操作:

import time

from selenium import webdriver
from selenium.webdriver import actionchains
from selenium.webdriver.common.by import by

# 初始化驱动

driver = webdriver.chrome()
# 窗口最大化
driver.maximize_window()

# 访问网址
driver.get('http://localhost:63342/webauto/day4/%e6%bb%91%e5%8a%a8%e9%aa%8c%e8%af%81.html')
time.sleep(2)
# 滑块定位
el = driver.find_element(by.xpath, '//div[@id="box"]/div[3]')
# 使用指针将滑块按住并移动,之后释放
actionchains(driver).click_and_hold(el).move_by_offset(300, 0).perform()

#获取执行结果
res = driver.find_element(by.xpath,'//div[@id="box"]/div[2]').text
if res == "解锁成功":
    print("用例通过")
else:
    print("用例失败")
#释放事件链
actionchains(driver).release()
time.sleep(5)
driver.quit()

指针也提供了click方法,点击方法与driver.find_element(by.xpath,'//div[@id="box"]/div[3]').click()一致,如下:

actionchains(driver).click(el).perform()

 三、页面刷新、后退一页、前进一页:

selenium提供了页面刷新,前进和后退的操作,对应在浏览器上的相应操作后退,前进,刷新

 对应的方法back(后退)、forward(前进)、refresh(刷新),代码如下:

import time
# 导入selenium包
from selenium import webdriver
from selenium.webdriver.common.by import by

# 启动并打开指定页面
driver = webdriver.chrome()
driver.get("http://www.csdn.net")
driver.maximize_window()
driver.find_element(by.link_text, 'python').click()
#停留2秒
time.sleep(2)
# 刷新页面
driver.refresh()
# 停留2秒
time.sleep(2)
# 页面后退一页
driver.back()
# 停留2秒
time.sleep(2)
# 前进一页
driver.forward()
# 关闭页面
time.sleep(3)

driver.quit()

四、内联框架

frame :html页面中的一种框架,主要作用是在当前页面中指定区域显示另一页面元素 。<iframe>标签规定一个内联框架,一个内联框架被用来在当前 html 文档中嵌入另一个文档,通过使用框架,你可以在同一个浏览器窗口中显示不止一个页面。

所以在我们进行操作时,明明就是当前页面,元素就是定位不到,需要考虑是否存在问题,下列是两个页面代码,其中index.html为主页面,存在frame内联框架,而iframe_content.html为被嵌入的页面

<!-- index.html -->
<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>带内联框架的页面</title>
    <style>
        iframe {
            width: 100%;
            height: 200px;
            border: none;
        }
    </style>
</head>
<body>

    <h1>带内联框架的页面</h1>

    <!-- 内联框架 -->
    <iframe id="myiframe" src="iframe_content.html"></iframe>

</body>
</html>

<!-- iframe_content.html -->
<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>内联框架内容</title>
</head>
<body>

    <h2>在内联框架内输入信息</h2>

    <!-- 输入框表单 -->
    <form onsubmit="return handleformsubmit();">
        <label for="userinput">输入信息:</label>
        <input type="text" id="userinput" name="userinput">
        <input type="submit" value="提交">
    </form>

    <script>
        function handleformsubmit() {
            var userinput = document.getelementbyid('userinput').value;
            // 这里可以添加代码来处理输入信息
            // 例如,将输入信息显示在iframe内或发送到服务器

            // 阻止表单的默认提交行为
            alert('输入内容:' + userinput); // 显示输入内容的简单示例
            return false;
        }
    </script>

</body>
</html>

往输入框输入文字,需要跳转到frame内联框架中,否则会报错,nosuchelement,代码如下:

from selenium import webdriver
from selenium.webdriver.common.by import by
import time


# 实例化浏览器对象
driver = webdriver.chrome()
# 打开网页
driver.get("http://localhost:63342/python_project/apiauto/index.html")
# 最大化窗口
driver.maximize_window()
# 等待2秒
time.sleep(2)
#进入内联框架
driver.switch_to.frame("myiframe")
# 等待2秒
time.sleep(2)
# 输入内容
driver.find_element(by.id,"userinput").send_keys("selenium")
time.sleep(2)
# 跳出内联框架
driver.switch_to.default_content()
# 获取内联框架外的h1标签内容
print(driver.find_element(by.xpath,'/html/body/h1').text)
driver.quit()

使用switch_to.frame(),进入到内联框架,之后再使用switch_to.default_content()跳出内联框架回去文本。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com