python_selenium

本文通过实例演示了如何使用Selenium进行自动化测试,包括启动浏览器、网页导航、元素定位及交互等基本操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文内容均来自51自学网整理,如果侵权请联系我

案例:

  • 启动火狐浏览器,
  • 首先打开我要自学网页面,打印网页标题,等待3秒
  • 打开百度首页,打印网页标题,再等待2秒
  • 关闭浏览器。
from selenium import  webdriver
from time  import sleep
#选择使用的浏览器
driver = webdriver.Firefox()
#打开的网页
driver.get("http://www.baidu.com")
#打印网页标题
print(driver.title)
sleep(3)
#打开另一个网页
driver.get("http://www.51zxw.net")
print(driver.title)
sleep(2)
#关闭
driver.quit()

浏览器操作

  • 浏览器窗口大小设置
  • 页面前进后退
  • 页面刷新
from selenium import webdriver
from time import sleep

driver=webdriver.Chrome()
driver.get("http://www.51zxw.net/show.aspx?id=60544&cid=615")
print(driver.page_source)
#窗口最大化
driver.maximize_window()
sleep(2)

driver.get("http://www.baidu.com")
#调整窗口尺寸
driver.set_window_size(800,400)
#刷新页面
driver.refresh()
#返回后退
driver.back()
sleep(2)
#前进
driver.forward()

元素定位

元素的定位应该是自动化测试的核心,要想操作一个元素,首先应该识别这个元素。

webdriver提供了一系列的元素定位方法,常用的有以下几种

  • id
  • name
  • class name
  • link text
  • partial link text
  • tag name
  • xpath
  • css selector

案例:打开百度首页,在搜索框自动输入“Selenium我要自学网关键词,然后点击搜索按钮,查看搜索页面。

from selenium import webdriver
from time import sleep
driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
#根据name  属性 输入查找的问题
driver.find_element_by_name("wd").send_keys("selenium 我要自学网")
sleep(2)
#点击搜索属性
driver.find_element_by_id('su').click()

tag_name定位

from selenium import webdriver
driver = webdriver.Chrome()
driver.get("http://www.51zxw.net/show.aspx?id=60546&cid=615")
#找到所有标签
inputs = driver.find_elements_by_tag_name("input")
#取出第一个input 标签赋值selenium
inputs[0].send_keys("selenium")
class_name定位

from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
#根据class 名字定位
driver.find_element_by_class_name("s_ipt").send_keys("selenium")
driver.find_element_by_id("su").click()

link_text定位

link_text定位就是根据超链接文字进行定位。

from selenium import webdriver
from time import  sleep
driver =webdriver.Chrome()
driver.get("http://www.51zxw.net/")
sleep(3)
#根据超链接文本查询
driver.find_element_by_link_text("程序开发").click()

sleep(3)
#跟局超链接文本部分内容查询
driver.find_element_by_partial_link_text("神秘面纱").click()

XPath定位

XPath即为XML路径语言,它是一种用来确定XML文档中某部分位置的语言。XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。

xpath绝对与相对定位
from selenium import webdriver
from time import  sleep
driver =bdriver.Chrome()
driver.get("http://www.baidu.com")
# 绝对路径定位
driver.find_element_by_xpath("/html/body/div[2]/div[1]/div/div[1]/div/form/span[1]/input").send_keys("selenium")
#根据input 标签中的ID定位
driver.find_element_by_xpath("//input[@id='kw']").send_keys("第二次")
#根据name 标签中的ID定位
driver.find_element_by_xpath("//input[@name='wd']").send_keys("第三次")
#所有标签中 属性为s_ipt的calss
driver.find_element_by_xpath("//*[@class='s_ipt']").send_keys("第四次")


xpath深入定位

from selenium import webdriver
from time import sleep

driver=webdriver.Firefox()

driver.get("http://www.51zxw.net")
#层级和属性结合定位--自学网首页输入用户和名密码
driver.find_element_by_xpath("//form[@id='loginForm']/ul/input[1]").send_keys("51zxw")
driver.find_element_by_xpath("//form[@id='loginForm']/ul/input[2]").send_keys("66666")

#逻辑运算组合定位
driver.find_element_by_xpath("//input[@type='text' and @name='username']").send_keys("51zxw")

sleep(3)
driver.quit()






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值